HarmonyOS HmacSHA1 加密算法 参数问题

项目需要用到 HmacSHA1 加密算法,请问下cryptoFramework.createMac 和 cryptoFramework.createSymKeyGenerator 两个方法需要传什么参数,或者能否给一个完整的例子?

HarmonyOS
1天前
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
aquaa

参考下demo:

import { cryptoFramework } from '@kit.CryptoArchitectureKit';
import { buffer } from '@kit.ArkTS';

@Entry
@Component
struct HmacSHaPage {
  @State message: string = 'Hello World';

  build() {
    Column(){
      Button('click').onClick(() => {
        getHmac('hello HarmonyOs')
      })

    }.height('100%').width('100%')
  }
}
// 可理解的字符串转成字节流
function stringToUint8Array(str: string) {
  let arr = new Uint8Array(str.length);
  for (let i = 0, j = str.length; i < j; ++i) {
    arr[i] = str.charCodeAt(i);
  }
  return arr;
}

async function getHmac(message: string) {
  try {
    let macAlgName = 'SHA1';
    let mac = cryptoFramework.createMac(macAlgName)
    let arr = stringToUint8Array('hello HarmonyOs')
    let KeyBlob: cryptoFramework.DataBlob = { data: arr };
    let symKeyGenerator = cryptoFramework.createSymKeyGenerator('HMAC');
    const symKey = await symKeyGenerator.convertKey(KeyBlob);
    await mac.init(symKey)
    await mac.update({ data: stringToUint8Array(message) });
    let macOutpt = await mac.doFinal();
    const res = buffer.from(macOutpt.data).toString('hex');
    console.log('Hmac—:' + res);
  } catch (err) {
    console.log('err:' + err)
  }
}
分享
微博
QQ
微信
回复
1天前
相关问题
HarmonyOS HmacSHA1加签算法实现
753浏览 • 1回复 待解决
HarmonyOSHmacSHA1加签算法实现?
135浏览 • 0回复 待解决
加解密HmacSha1HmacSha256、aes参考Demo
2218浏览 • 1回复 待解决
HarmonyOS RSA加密算法实现
36浏览 • 1回复 待解决
HarmonyOS AES加密算法demo
28浏览 • 1回复 待解决
安全加密算法代码参考
1804浏览 • 1回复 待解决
HarmonyOS SM2加密算法
18浏览 • 1回复 待解决
HarmonyOS 需要MD5加密算法
44浏览 • 1回复 待解决
HarmonyOS MD5加密算法demo
31浏览 • 1回复 待解决
HarmonyOS 是否有带iv的DES加密算法
516浏览 • 1回复 待解决
加密算法(crypto-js)Arkts转化代码
1144浏览 • 1回复 待解决
HarmonyOS HmacSHA256算法
34浏览 • 1回复 待解决
是否有AES的ECB模式的加密算法
579浏览 • 1回复 待解决
ECC算法是否支持secp256r1
630浏览 • 1回复 待解决
HarmonyOS 有没有sha1加密库可以用
26浏览 • 1回复 待解决
HarmonyOS hmac加密问题
258浏览 • 1回复 待解决
签名验签算法不支持RSA|PKCS8|SHA1
275浏览 • 1回复 待解决