1# 消息摘要计算SHA256(ArkTS) 2 3对应的算法规格请查看[消息摘要计算算法规格](crypto-generate-message-digest-overview.md#支持的算法与规格)。 4 5> **说明:** 6> 7> 从API version 12开始,轻量级智能穿戴设备支持消息摘要的计算与操作。 8 9## 开发步骤 10 11在调用update接口传入数据时,可以[一次性传入所有数据](#摘要算法一次性传入),也可以把数据人工分段,然后[分段update](#分段摘要算法)。对于同一段数据而言,计算结果没有差异。对于数据量较大的数据,开发者可以根据实际需求选择是否分段传入。 12 13下面分别提供两种方式的示例代码。 14 15### 摘要算法(一次性传入) 16 171. 调用[cryptoFramework.createMd](../../reference/apis-crypto-architecture-kit/js-apis-cryptoFramework.md#cryptoframeworkcreatemd),指定摘要算法SHA256,生成摘要实例(Md)。 18 192. 调用[Md.update](../../reference/apis-crypto-architecture-kit/js-apis-cryptoFramework.md#update-6),传入自定义消息,进行摘要更新计算。单次update长度没有限制。 20 213. 调用[Md.digest](../../reference/apis-crypto-architecture-kit/js-apis-cryptoFramework.md#digest),获取摘要计算结果。 22 234. 调用[Md.getMdLength](../../reference/apis-crypto-architecture-kit/js-apis-cryptoFramework.md#getmdlength),获取摘要计算长度,单位为字节。 24 25- 以使用await方式单次传入数据,获取摘要计算结果为例: 26 27 ```ts 28 import { cryptoFramework } from '@kit.CryptoArchitectureKit'; 29 import { buffer } from '@kit.ArkTS'; 30 31 async function doMd() { 32 let mdAlgName = 'SHA256'; // 摘要算法名。 33 let message = 'mdTestMessage'; // 待摘要的数据。 34 let md = cryptoFramework.createMd(mdAlgName); 35 // 数据量较少时,可以只做一次update,将数据全部传入,接口未对入参长度做限制。 36 await md.update({ data: new Uint8Array(buffer.from(message, 'utf-8').buffer) }); 37 let mdResult = await md.digest(); 38 console.info('Md result:' + mdResult.data); 39 let mdLen = md.getMdLength(); 40 console.info("md len: " + mdLen); 41 } 42 ``` 43 44- 以使用同步方式单次传入数据,获取摘要计算结果为例: 45 46 ```ts 47 import { cryptoFramework } from '@kit.CryptoArchitectureKit'; 48 import { buffer } from '@kit.ArkTS'; 49 50 function doMdBySync() { 51 let mdAlgName = 'SHA256'; // 摘要算法名。 52 let message = 'mdTestMessage'; // 待摘要的数据。 53 let md = cryptoFramework.createMd(mdAlgName); 54 // 数据量较少时,可以只做一次update,将数据全部传入,接口未对入参长度做限制。 55 md.updateSync({ data: new Uint8Array(buffer.from(message, 'utf-8').buffer) }); 56 let mdResult = md.digestSync(); 57 console.info('[Sync]:Md result:' + mdResult.data); 58 let mdLen = md.getMdLength(); 59 console.info("md len: " + mdLen); 60 } 61 ``` 62 63### 分段摘要算法 64 651. 调用[cryptoFramework.createMd](../../reference/apis-crypto-architecture-kit/js-apis-cryptoFramework.md#cryptoframeworkcreatemd),指定摘要算法SHA256,生成摘要实例(Md)。 66 672. 传入自定义消息,将一次传入数据量设置为20字节,多次调用[Md.update](../../reference/apis-crypto-architecture-kit/js-apis-cryptoFramework.md#update-7),进行摘要更新计算。 68 693. 调用[Md.digest](../../reference/apis-crypto-architecture-kit/js-apis-cryptoFramework.md#digest-1),获取摘要计算结果。 70 714. 调用[Md.getMdLength](../../reference/apis-crypto-architecture-kit/js-apis-cryptoFramework.md#getmdlength),获取摘要计算长度,单位为字节。 72 73- 以使用await方式分段传入数据,获取摘要计算结果为例: 74 75 ```ts 76 import { cryptoFramework } from '@kit.CryptoArchitectureKit'; 77 import { buffer } from '@kit.ArkTS'; 78 79 async function doLoopMd() { 80 let mdAlgName = "SHA256"; // 摘要算法名。 81 let md = cryptoFramework.createMd(mdAlgName); 82 // 假设信息总共43字节,根据utf-8解码后,也是43字节。 83 let messageText = "aaaaa.....bbbbb.....ccccc.....ddddd.....eee"; 84 let messageData = new Uint8Array(buffer.from(messageText, 'utf-8').buffer); 85 let updateLength = 20; // 假设以20字节为单位进行分段update,实际并无要求。 86 for (let i = 0; i < messageData.length; i += updateLength) { 87 let updateMessage = messageData.subarray(i, i + updateLength); 88 let updateMessageBlob: cryptoFramework.DataBlob = { data: updateMessage }; 89 await md.update(updateMessageBlob); 90 } 91 let mdOutput = await md.digest(); 92 console.info("md result: " + mdOutput.data); 93 let mdLen = md.getMdLength(); 94 console.info("md len: " + mdLen); 95 } 96 ``` 97 98- 以使用同步方式分段传入数据,获取摘要计算结果为例: 99 100 ```ts 101 import { cryptoFramework } from '@kit.CryptoArchitectureKit'; 102 import { buffer } from '@kit.ArkTS'; 103 104 function doLoopMdBySync() { 105 let mdAlgName = "SHA256"; // 摘要算法名。 106 let md = cryptoFramework.createMd(mdAlgName); 107 // 假设信息总共43字节,根据utf-8解码后,也是43字节。 108 let messageText = "aaaaa.....bbbbb.....ccccc.....ddddd.....eee"; 109 let messageData = new Uint8Array(buffer.from(messageText, 'utf-8').buffer); 110 let updateLength = 20; // 假设以20字节为单位进行分段update,实际并无要求。 111 for (let i = 0; i < messageData.length; i += updateLength) { 112 let updateMessage = messageData.subarray(i, i + updateLength); 113 let updateMessageBlob: cryptoFramework.DataBlob = { data: updateMessage }; 114 md.updateSync(updateMessageBlob); 115 } 116 let mdOutput = md.digestSync(); 117 console.info("[Sync]:md result: " + mdOutput.data); 118 let mdLen = md.getMdLength(); 119 console.info("md len: " + mdLen); 120 } 121 ```