harmony 鸿蒙消息摘要计算MD5(ArkTS)

  • 2025-06-16
  • 浏览 (5)

消息摘要计算MD5(ArkTS)

对应的算法规格请查看消息摘要计算算法规格

说明:

从API version 12开始,轻量级智能穿戴设备支持消息摘要的计算与操作。

开发步骤

在调用update接口传入数据时,可以一次性传入所有数据,也可以把数据人工分段,然后分段update。对于同一段数据而言,计算结果没有差异。对于数据量较大的数据,开发者可以根据实际需求选择是否分段传入。

下面分别提供两种方式的示例代码。

摘要算法(一次性传入)

  1. 调用cryptoFramework.createMd,指定摘要算法MD5,生成摘要实例(Md)。

  2. 调用Md.update,传入自定义消息,进行摘要更新计算。单次update长度没有限制。

  3. 调用Md.digest,获取摘要计算结果。

  4. 调用Md.getMdLength,获取摘要计算长度,单位为字节。

  5. 以使用await方式单次传入数据,获取摘要计算结果为例:

  import { cryptoFramework } from '@kit.CryptoArchitectureKit';
  import { buffer } from '@kit.ArkTS';

  async function doMd() {
    let mdAlgName = 'MD5'; // 摘要算法名。
    let message = 'mdTestMessage'; // 待摘要的数据。
    let md = cryptoFramework.createMd(mdAlgName);
    // 数据量较少时,可以只做一次update,将数据全部传入,接口未对入参长度做限制。
    await md.update({ data: new Uint8Array(buffer.from(message, 'utf-8').buffer) });
    let mdResult = await md.digest();
    console.info('Md result:' + mdResult.data);
    let mdLen = md.getMdLength();
    console.info("md len: " + mdLen);
  }
  • 以使用同步方式单次传入数据,获取摘要计算结果为例:
  import { cryptoFramework } from '@kit.CryptoArchitectureKit';
  import { buffer } from '@kit.ArkTS';

  function doMdBySync() {
    let mdAlgName = 'MD5'; // 摘要算法名。
    let message = 'mdTestMessage'; // 待摘要的数据。
    let md = cryptoFramework.createMd(mdAlgName);
    // 数据量较少时,可以只做一次update,将数据全部传入,接口未对入参长度做限制。
    md.updateSync({ data: new Uint8Array(buffer.from(message, 'utf-8').buffer) });
    let mdResult = md.digestSync();
    console.info('[Sync]:Md result:' + mdResult.data);
    let mdLen = md.getMdLength();
    console.info("md len: " + mdLen);
  }

分段摘要算法

  1. 调用cryptoFramework.createMd,指定摘要算法MD5,生成摘要实例(Md)。

  2. 传入自定义消息,将一次传入数据量设置为20字节,多次调用Md.update,进行摘要更新计算。

  3. 调用Md.digest,获取摘要计算结果。

  4. 调用Md.getMdLength,获取摘要计算长度,单位为字节。

  5. 以使用await方式分段传入数据,获取摘要计算结果为例:

  import { cryptoFramework } from '@kit.CryptoArchitectureKit';
  import { buffer } from '@kit.ArkTS';

  async function doLoopMd() {
    let mdAlgName = "MD5"; // 摘要算法名。
    let md = cryptoFramework.createMd(mdAlgName);
    // 假设信息总共43字节,根据utf-8解码后,也是43字节。
    let messageText = "aaaaa.....bbbbb.....ccccc.....ddddd.....eee";
    let messageData = new Uint8Array(buffer.from(messageText, 'utf-8').buffer);
    let updateLength = 20; // 假设以20字节为单位进行分段update,实际并无要求。
    for (let i = 0; i < messageData.length; i += updateLength) {
      let updateMessage = messageData.subarray(i, i + updateLength);
      let updateMessageBlob: cryptoFramework.DataBlob = { data: updateMessage };
      await md.update(updateMessageBlob);
    }
    let mdOutput = await md.digest();
    console.info("md result: " + mdOutput.data);
    let mdLen = md.getMdLength();
    console.info("md len: " + mdLen);
  }
  • 以使用同步方式分段传入数据,获取摘要计算结果为例:
  import { cryptoFramework } from '@kit.CryptoArchitectureKit';
  import { buffer } from '@kit.ArkTS';

  function doLoopMdBySync() {
    let mdAlgName = "MD5"; // 摘要算法名。
    let md = cryptoFramework.createMd(mdAlgName);
    // 假设信息总共43字节,根据utf-8解码后,也是43字节。
    let messageText = "aaaaa.....bbbbb.....ccccc.....ddddd.....eee";
    let messageData = new Uint8Array(buffer.from(messageText, 'utf-8').buffer);
    let updateLength = 20; // 假设以20字节为单位进行分段update,实际并无要求。
    for (let i = 0; i < messageData.length; i += updateLength) {
      let updateMessage = messageData.subarray(i, i + updateLength);
      let updateMessageBlob: cryptoFramework.DataBlob = { data: updateMessage };
      md.updateSync(updateMessageBlob);
    }
    let mdOutput = md.digestSync();
    console.info("[Sync]:md result: " + mdOutput.data);
    let mdLen = md.getMdLength();
    console.info("md len: " + mdLen);
  }

你可能感兴趣的鸿蒙文章

harmony 鸿蒙Crypto Architecture Kit(加解密算法框架服务)

harmony 鸿蒙使用3DES对称密钥(ECB模式)加解密(C/C++)

harmony 鸿蒙使用3DES对称密钥(ECB模式)加解密(ArkTS)

harmony 鸿蒙使用AES对称密钥(CBC模式)加解密(C/C++)

harmony 鸿蒙使用AES对称密钥(CBC模式)加解密(ArkTS)

harmony 鸿蒙使用AES对称密钥(CCM模式)加解密(C/C++)

harmony 鸿蒙使用AES对称密钥(CCM模式)加解密(ArkTS)

harmony 鸿蒙使用AES对称密钥(ECB模式)加解密(C/C++)

harmony 鸿蒙使用AES对称密钥(ECB模式)加解密(ArkTS)

harmony 鸿蒙使用AES对称密钥(GCM模式)分段加解密(C/C++)

0  赞