harmony-utils之MD5,MD5工具类

简介: harmony-utils 是一款功能丰富的 HarmonyOS 工具库,提供包括 MD5 加密在内的多种实用工具类,帮助开发者高效构建鸿蒙应用。

harmony-utils之MD5,MD5工具类

harmony-utils 简介与说明


harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
picker_utils 是harmony-utils拆分出来的一个子库,包含PickerUtil、PhotoHelper、ScanUtil。

下载安装
ohpm i @pura/harmony-utils
ohpm i @pura/picker_utils

  //全局初始化方法,在UIAbility的onCreate方法中初始化 AppUtil.init()
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    AppUtil.init(this.context);
  }

MD5 算法简介


MD5(Message-Digest Algorithm 5)是由Ronald Rivest于1991年设计的密码散列函数,可将任意长度数据生成128位(16字节)的固定长度哈希值。其核心通过‌填充-分块-循环压缩‌流程实现:先对输入补位至512位倍数,再分块进行4轮非线性运算(每轮16次操作),最终输出唯一性摘要。
该算法曾广泛用于文件完整性校验(如软件包校验)、密码存储及数字证书签名。但因存在碰撞漏洞(可人为构造相同哈希的不同数据),自2004年被证实不抗碰撞攻击后,逐步被SHA-256等更安全算法替代。目前仍见于非敏感场景如缓存标识或数据去重。因MD5存在碰撞攻击风险(王小云团队2004年破解),金融、政务等关键领域已禁用,推荐改用SM3/SHA-256。

API方法与使用


digest MD5摘要
let str1 = "鸿蒙技术交流群:xxxxxxxxxxx";

let digest1 = await MD5.digest(str1);
LogUtil.error(`摘要,异步: ${digest1}`);

let digest2 = MD5.digestSync(str1);
LogUtil.error(`摘要,同步1: ${digest2}`);

let digest3 = MD5.digestSync(str1, 'base64');
LogUtil.error(`摘要,同步2: ${digest3}`);
digestSegment MD5摘要,分段
let str3 = "harmony-utils,一款高效的HarmonyOS工具包,封装了常用工具类,提供一系列简单易用的方法。帮助开发者快速构建鸿蒙应用。";

let digest1 = await MD5.digestSegment(str3);
LogUtil.error(`分段摘要,异步: ${digest1}`);

let digest2 = MD5.digestSegmentSync(str3);
LogUtil.error(`分段摘要,同步1: ${digest2}`);

let digest3 = MD5.digestSegmentSync(str3, 'base64', 256);
LogUtil.error(`分段摘要,同步2: ${digest3}`);
hmac 消息认证码计算
let symKey = CryptoUtil.generateSymKeySync("AES256");
let str1 = "鸿蒙技术交流群:xxxxxxxxxxx";

let digest1 = await MD5.hmac(str1, symKey);
LogUtil.error(`消息认证码计算,异步: ${digest1}`);

let digest2 = MD5.hmacSync(str1, symKey);
LogUtil.error(`消息认证码计算,同步1: ${digest2}`);

let digest3 = MD5.hmacSync(str1, symKey, 'base64');
LogUtil.error(`消息认证码计算,同步2: ${digest3}`);
hmacSegment 消息认证码计算,分段
let symKey = CryptoUtil.generateSymKeySync("AES256");
let str3 = "harmony-utils,一款高效的HarmonyOS工具包,封装了常用工具类,提供一系列简单易用的方法。帮助开发者快速构建鸿蒙应用。";

let digest1 = await MD5.hmacSegment(str3, symKey);
LogUtil.error(`分段消息认证码计算,异步: ${digest1}`);

let digest2 = MD5.hmacSegmentSync(str3, symKey);
LogUtil.error(`分段消息认证码计算,同步1: ${digest2}`);

let digest3 = MD5.hmacSegmentSync(str3, symKey, 'hex', 256);
LogUtil.error(`分段消息认证码计算,同步2: ${digest3}`);
目录
相关文章
|
5月前
|
JSON 算法 安全
harmony-utils之SM4,SM4加解密
harmony-utils是一款专为HarmonyOS开发的高效工具库,提供丰富的实用功能,如SM4加解密、设备操作、文件处理等,助力开发者快速构建鸿蒙应用。
321 0
|
存储 算法 安全
harmony-utils之SHA,SHA工具类
harmony-utils 是一款功能丰富的 HarmonyOS 工具库,提供多种实用工具类,助力开发者快速构建鸿蒙应用。其中的 SHA 工具类支持 SHA-1、SHA-2、SHA-3 等算法,可用于数据摘要、完整性校验、数字签名和密码存储等场景。支持同步与异步操作,并提供分段处理及 HMAC 消息认证码计算功能,提升安全性和灵活性。
205 1
|
5月前
|
iOS开发
harmony-dialog预览效果
harmony-dialog 是一款简单易用、零侵入的弹窗组件,支持多种类型如确认框、提示框、输入框、选择器、加载框等,覆盖常见开发需求。
167 0
harmony-dialog预览效果
|
5月前
|
JSON 安全 生物认证
harmony-utils之PhotoHelper,相册相关工具类
harmony-utils 是一款功能丰富的 HarmonyOS 工具库,助力开发者快速构建鸿蒙应用。其子模块 picker_utils 中的 PhotoHelper 提供了便捷的相册操作功能,涵盖图片视频选择、保存、读取及授权管理等常用场景,简化开发流程,提升开发效率。
213 0
|
算法 网络安全 区块链
harmony-utils之ECDSA,ECDSA工具类
`harmony-utils` 是一款功能丰富的 HarmonyOS 工具库,提供包括 ECDSA 签名与验签在内的多种实用工具,助力开发者高效构建鸿蒙应用。
185 0
|
JSON 安全 算法
harmony-utils之DES,DES加解密
harmony-utils 是一款专为HarmonyOS开发的高效工具库,提供包括DES加解密在内的多种功能。支持异步与同步加密、多种加密模式(ECB、CBC、OFB等),助力开发者快速实现安全数据处理。
169 0
|
5月前
|
JSON 生物认证 API
harmony-utils之PickerUtil,拍照、文件选择和保存,工具类
PickerUtil 是 harmony-utils 工具库的子模块,提供拍照、相册选择、文件管理等功能,简化鸿蒙应用开发中的资源选取与保存操作。
163 0
|
5月前
|
JSON 编解码 API
harmony-utils之Base64Util,Base64工具类
`harmony-utils` 是一款功能丰富的 HarmonyOS 工具库,提供 Base64 编解码、字符串转换等实用功能,助力开发者高效构建鸿蒙应用。
188 0
|
存储 安全 算法
harmony-utils之AES,AES加解密
harmony-utils是一款专为HarmonyOS开发的高效工具库,提供包括AES加解密在内的多种实用功能,帮助开发者快速构建应用。
299 0
|
5月前
|
前端开发 UED
HarmonyOS应用一键置灰指南
一键置灰常用于重大悼念、特殊纪念日、模拟视觉效果及系统维护等场景,可通过组件属性、窗口设置或工具库实现界面整体或局部灰度效果,操作简便且提升用户体验与情感共鸣。
235 0