HarmonyOS sm4加密有无cbc方式

HarmonyOS
2024-12-27 16:54:56
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
Excelsior_abit

SM4有cbc方式,参考以下规格文档:https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/security/CryptoArchitectureKit/crypto-sym-encrypt-decrypt-spec.md#sm4

async function SM4ED(plainText: string) {
  let sm4Generator = cryptoFramework.createSymKeyGenerator('SM4_128');
  let cipher = cryptoFramework.createCipher("SM4_128|CBC|PKCS7");
  let decoder = cryptoFramework.createCipher("SM4_128|CBC|PKCS7");
  let input: cryptoFramework.DataBlob = { data: stringToUint8Array(plainText) };

  let keydata: cryptoFramework.DataBlob = { data: stringToUint8Array('yc1436w86vhys51r') }; //密钥

  let ivdata: cryptoFramework.DataBlob = { data: stringToUint8Array('43pr5253zf5mm7jd') }; //偏移
  let iv: cryptoFramework.IvParamsSpec = { iv: ivdata, algName: 'IvParamsSpec' } //cbc模式的参数 不需要可以不写
  let key: cryptoFramework.SymKey

  try {
    key = await sm4Generator.convertKey(keydata);
    // 加密
    // 最后一个参数是偏移量的设置,如果没有则为null,下面解密同理
    await cipher.init(cryptoFramework.CryptoMode.ENCRYPT_MODE, key, null);
    let cipherData = await cipher.doFinal(input)

    //解密
    await decoder.init(cryptoFramework.CryptoMode.DECRYPT_MODE, key, null);
    let result = await decoder.doFinal(cipherData);

    //解密后的明文
    let str = uint8ArrayToString(result.data)
    AlertDialog.show({ message: "decrypt success ==>" + str })
  } catch (err) {
    console.error(err)
  }
}
分享
微博
QQ
微信
回复
2024-12-27 19:02:04
相关问题
HarmonyOS 没找到 sm4 cbc 加密
264浏览 • 1回复 待解决
HarmonyOS SM4加密
102浏览 • 1回复 待解决
HarmonyOS SM4如何进行SM4/ECB/NoPadding加密
262浏览 • 1回复 待解决
如何使用SM4CBC模式加解密
1509浏览 • 1回复 待解决
HarmonyOS sm4 支持 CBC PKCS5Padding 吗
184浏览 • 1回复 待解决
SM4 CBC模式加解密,有好的方案吗?
1441浏览 • 1回复 待解决
HarmonyOS SM2/SM4结合加解密
456浏览 • 1回复 待解决
SM4采用OFB模式进行加解密
1423浏览 • 1回复 待解决
HarmonyOS SM4-ECB-NoPadding加密
253浏览 • 1回复 待解决
HarmonyOS SM2,SM4国密加解密使用demo
639浏览 • 1回复 待解决
HarmonyOS sm4、rsa等加解密库及参考文档
1058浏览 • 1回复 待解决
想了解一下SM4相关案例
1159浏览 • 1回复 待解决
HarmonyOS AES CBC加密问题
870浏览 • 1回复 待解决
HarmonyOS AES128|CBC|NoPadding 加密报错
312浏览 • 1回复 待解决