HarmonyOS 鸿蒙Next ArkTs中DES/ECB/PKCS5Padding加密怎么写?

发布于 1周前 作者 ionicwang 来自 鸿蒙OS

HarmonyOS 鸿蒙Next ArkTs中DES/ECB/PKCS5Padding加密怎么写?

密钥:tRYH6CNDMzlrJC6hxtiZjOswBjs3ajXnW9xqNyoGX5M0uKvnYgIRBGlL0ZIy

arkyts只有3des,试了很多工具类,最后结果都不对,弄了两天了,上面是Android代码,有没有大佬帮我看看ts该怎么写,谢谢!

2 回复

可以使用三方库:[@ohos/crypto-js](https://ohpm.openharmony.cn/#/cn/detail/)

let encrypted = CryptoJS.DES.encrypt("qwefgthytn", "crernti",{
  mode: CryptoJS.mode.CBC,
  padding: CryptoJS.pad.Pkcs7
})
console.log(encrypted.toString())

let decrypted = CryptoJS.DES.decrypt(encrypted,"crernti",{
  mode: CryptoJS.mode.CBC,
  padding: CryptoJS.pad.Pkcs7
})
let decryptedString = CryptoJS.enc.Utf8.stringify(decrypted);
console.log(decryptedString)

更多关于HarmonyOS 鸿蒙Next ArkTs中DES/ECB/PKCS5Padding加密怎么写?的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


在HarmonyOS鸿蒙系统的Next ArkTs框架中,进行DES/ECB/PKCS5Padding加密,可以通过以下代码实现。这里假设你已经熟悉ArkTs的基本开发环境,并且已经引入了必要的加密库。

首先,确保你的项目中包含了加密相关的依赖库。在ArkTs中,通常可以通过配置文件或者包管理工具来引入这些库。

然后,使用以下代码进行DES/ECB/PKCS5Padding加密:

import crypto from '@ohos.security.crypto';

function desEncryptECBPKCS5Padding(key: ArrayBuffer, data: ArrayBuffer): ArrayBuffer {
    let cipher = crypto.createCipher({
        algorithm: 'DES',
        mode: 'ECB',
        padding: 'PKCS5Padding',
        key: key
    });
    return cipher.update(data) + cipher.final();
}

// 示例用法
let key = new ArrayBuffer(8); // DES密钥长度为8字节
let data = new TextEncoder().encode("Hello World"); // 要加密的数据
// 填充key数据(这里仅为示例,实际使用中需要安全的密钥)
for (let i = 0; i < 8; i++) {
    key[i] = 0x01;
}

let encryptedData = desEncryptECBPKCS5Padding(key, data);
console.log(new Uint8Array(encryptedData));

如果问题依旧没法解决请联系官网客服,官网地址是 https://www.itying.com/category-93-b0.html

回到顶部