HarmonyOS 对称加密不支持AES|CBC|NoPadding模式
1、文档描述API10后,支持对称加解密不带密钥长度的规格,测试发现不支持createSymKeyGenerator('AES')写法。
https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/crypto-sym-encrypt-decrypt-spec-V5
2、对称加密不支持AES|CBC|NoPadding模式
function genIvParamsSpec() {
let arr = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]; // 16 bytes
let dataIv = new Uint8Array(arr);
let ivBlob: cryptoFramework.DataBlob = { data: dataIv };
let ivParamsSpec: cryptoFramework.IvParamsSpec = {
algName: "IvParamsSpec",
iv: ivBlob
};
return ivParamsSpec;
}
// 加密消息
function encryptMessage(symKey: cryptoFramework.SymKey, plainText: cryptoFramework.DataBlob) {
let cipher = cryptoFramework.createCipher('AES|CBC|NoPadding');
let iv = genIvParamsSpec();
cipher.initSync(cryptoFramework.CryptoMode.ENCRYPT_MODE, symKey, iv);
let cipherData = cipher.doFinalSync(plainText);
return cipherData;
}
// 解密消息
function decryptMessage(symKey: cryptoFramework.SymKey, cipherText: cryptoFramework.DataBlob) {
let decoder = cryptoFramework.createCipher('AES|CBC|NoPadding');
let iv = genIvParamsSpec();
decoder.initSync(cryptoFramework.CryptoMode.DECRYPT_MODE, symKey, iv);
let decryptData = decoder.doFinalSync(cipherText);
return decryptData;
}
async function genSymKeyByData(symKeyData: Uint8Array) {
let symKeyBlob: cryptoFramework.DataBlob = { data: symKeyData };
let aesGenerator = cryptoFramework.createSymKeyGenerator('AES128');
let symKey = await aesGenerator.convertKey(symKeyBlob);
console.info('cwq convertKey success');
return symKey;
}
async function main() {
try {
let keyData = new Uint8Array([83, 217, 231, 76, 28, 113, 23, 219, 250, 71, 209, 210, 205, 97, 32, 159]);
let symKey = await genSymKeyByData(keyData);
let message = "This is a test";
let plainText: cryptoFramework.DataBlob = { data: new Uint8Array(buffer.from(message, 'utf-8').buffer) };
let encryptText = encryptMessage(symKey, plainText);
let decryptText = decryptMessage(symKey, encryptText);
if (plainText.data.toString() === decryptText.data.toString()) {
console.info('cwq decrypt ok');
console.info('cwq decrypt plainText: ' + buffer.from(decryptText.data).toString('utf-8'));
} else {
console.error('cwq decrypt failed');
}
} catch (error) {
console.error(`cwq AES CBC “${error}“, error code: ${error.code}`);
}
}
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
- 9.
- 10.
- 11.
- 12.
- 13.
- 14.
- 15.
- 16.
- 17.
- 18.
- 19.
- 20.
- 21.
- 22.
- 23.
- 24.
- 25.
- 26.
- 27.
- 28.
- 29.
- 30.
- 31.
- 32.
- 33.
- 34.
- 35.
- 36.
- 37.
- 38.
- 39.
- 40.
- 41.
- 42.
- 43.
- 44.
- 45.
- 46.
- 47.
- 48.
- 49.
- 50.
- 51.
- 52.
- 53.
HarmonyOS
赞
收藏 0
回答 1
相关问题
HarmonyOS AES128/CBC/NoPadding加密模式报错
679浏览 • 1回复 待解决
HarmonyOS AES128|CBC|NoPadding 加密报错
659浏览 • 1回复 待解决
HarmonyOS 使用AES对称密钥(CBC模式)加解密
686浏览 • 1回复 待解决
使用AES对称密钥(CBC模式)加解密,生成symKey失败
1438浏览 • 1回复 待解决
HarmonyOS AES CBC加密问题
1213浏览 • 1回复 待解决
RSA NoPadding模式加密失败
2181浏览 • 1回复 待解决
HarmonyOS 压缩(.zip)文件进行加密问题,AES|CBC
949浏览 • 1回复 待解决
使用AES CBC模式加解密,convertKey报错401
1201浏览 • 1回复 待解决
HarmonyOS AES加密CBC模式中IV的实现,ArkTS和C++怎么对应上
1068浏览 • 1回复 待解决
HarmonyOS中AES加密CBC模式中IV的实现,ArkTS和C++怎么对应上?
524浏览 • 0回复 待解决
HarmonyOS harmonyOS定义不支持公钥加密,如何解决
886浏览 • 1回复 待解决
HarmonyOS 使用3DES对称密钥如何进行 CBC模式加解密
839浏览 • 1回复 待解决
支持那些国际加密算法?对于不支持的加密算法解决方案是什么?
992浏览 • 1回复 待解决
HarmonyOS 编码集不支持
757浏览 • 1回复 待解决
HarmonyOS 推送设备不支持
797浏览 • 1回复 待解决
HarmonyOS AES-CBC加解密
854浏览 • 1回复 待解决
HarmonyOS SM4-ECB-NoPadding加密
614浏览 • 1回复 待解决
Toggle isOn不支持$$?
788浏览 • 1回复 待解决
HarmonyOS AES加密,cbc,PKCS5Padding使用string的key,能否提供示例代码
799浏览 • 1回复 待解决
HarmonyOS 非对称加密:Ecc加密方式如何支持secp256k1
509浏览 • 1回复 待解决
web组件不支持localstorage
1490浏览 • 1回复 待解决
是否有AES的ECB模式的加密算法
1378浏览 • 1回复 待解决
是否支持jit和aot(jit不支持,aot支持),如果不支持jit怎么动态下发
2962浏览 • 1回复 待解决
HarmonyOS AES加密
691浏览 • 1回复 待解决
HarmonyOS @State不支持HashMap吗
735浏览 • 1回复 待解决
使用NoPadding密钥和明文长度一致啊,有限制的,可以用PKCS5、PKCS7就行