• 【Harmony OS】【ARK UI】ets使用第三方类库crypto实现加密解密


    在我们的日常开发过程中会经常用到加密解密,数字签名,信息加密是前后端开发经常使用的技术。应用场景包括:用户登录,交易,信息通讯等。
    今天分享一下AES加密解密方法,它是通过第三方类库CryptoJS来实现的
    1.DevEcoStudio 新建ets项目,在Terminal命令行界面输入
    npm install crypto-js --save 下载库
    安装完成以后刷新工程会生成node_modules目录

    image.png

    关于鸿蒙ets项目如何npm方式引入第三方js类库
    参考链接:
    华为开发者论坛

    2.代码如下:

    1. import CryptoJS from 'crypto-js';
    2. @Entry
    3. @Component
    4. struct ParentView {
    5. public onclieck(){
    6. console.log("1111111")
    7. let pas=this.Encrypt(123456+"")
    8. console.log(this.Decrypt(pas))
    9. }
    10. //解密方法
    11. Decrypt(word) {
    12. const key = CryptoJS.enc.Utf8.parse("1234123412ABCDEF"); //十六位十六进制数作为密钥
    13. const iv = CryptoJS.enc.Utf8.parse('ABCDEF1234123412'); //十六位十六进制数作为密钥偏移量
    14. let encryptedHexStr = CryptoJS.enc.Hex.parse(word);
    15. let srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
    16. let decrypt = CryptoJS.AES.decrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 });
    17. let decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
    18. console.log(decryptedStr.toString())
    19. return decryptedStr.toString();
    20. }
    21. //加密方法
    22. Encrypt(word) {
    23. const key = CryptoJS.enc.Utf8.parse("1234123412ABCDEF"); //十六位十六进制数作为密钥
    24. const iv = CryptoJS.enc.Utf8.parse('ABCDEF1234123412'); //十六位十六进制数作为密钥偏移量
    25. let srcs = CryptoJS.enc.Utf8.parse(word);
    26. let encrypted = CryptoJS.AES.encrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 });
    27. console.log(encrypted.ciphertext.toString().toUpperCase())
    28. return encrypted.ciphertext.toString().toUpperCase();
    29. }
    30. build() {
    31. Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
    32. Text('11111')
    33. .fontSize(50)
    34. .fontWeight(FontWeight.Bold)
    35. .onClick(this.onclieck.bind(this))
    36. }
    37. .width('100%')
    38. .height('100%')
    39. }
    40. }

    【注】:加密的时候必须转成字符串,使用toString.解密的时候,必须使用utf8的格式
    3运行效果如下:

    image.png

    参考链接:
    前端js几种加密/解密方法 - pinkpolk - 博客园

    欲了解更多更全技术文章,欢迎访问:https://developer.huawei.com/consumer/cn/forum/topic/0201802514778160388?fid=0102683795438680754?ha_source=zzh

     

  • 相关阅读:
    数据库管理-第四十二期 复盘一下(20221104)
    vue2项目从0搭建(二):配置代理,登录功能和菜单权限
    231n--CNN 卷积神经网络
    C++&qt Day9
    MySQL 开启SSL无效问题
    LeetCode_二分搜索_容斥原理_困难_878.第 N 个神奇数字
    FPGA控制W5500完成UDP环回测试
    习题10-4 递归求简单交错幂级数的部分和
    3.3 栈的表示和操作的实现
    [SSTF 2022] 三星安全论坛的小比赛错过了
  • 原文地址:https://blog.csdn.net/weixin_44708240/article/details/126058262