1e41f4b71Sopenharmony_ci# HMAC(ArkTS)
2e41f4b71Sopenharmony_ci
3e41f4b71Sopenharmony_ci
4e41f4b71Sopenharmony_ciHMAC是密钥相关的哈希运算消息认证码(Hash-based Message Authentication Code),是一种基于Hash函数和密钥进行消息认证的方法。
5e41f4b71Sopenharmony_ci
6e41f4b71Sopenharmony_ci
7e41f4b71Sopenharmony_ci
8e41f4b71Sopenharmony_ci## 开发步骤
9e41f4b71Sopenharmony_ci
10e41f4b71Sopenharmony_ci**生成密钥**
11e41f4b71Sopenharmony_ci
12e41f4b71Sopenharmony_ci1. 指定密钥别名。
13e41f4b71Sopenharmony_ci
14e41f4b71Sopenharmony_ci2. 初始化密钥属性集。
15e41f4b71Sopenharmony_ci
16e41f4b71Sopenharmony_ci3. 调用[generateKeyItem](../../reference/apis-universal-keystore-kit/js-apis-huks.md#huksgeneratekeyitem9)生成密钥,HMAC支持的规格请参考[密钥生成](huks-key-generation-overview.md#支持的算法)。
17e41f4b71Sopenharmony_ci
18e41f4b71Sopenharmony_ci除此之外,开发者也可以参考[密钥导入](huks-key-import-overview.md#支持的算法)的规格介绍,导入已有的密钥。
19e41f4b71Sopenharmony_ci
20e41f4b71Sopenharmony_ci**执行HMAC**
21e41f4b71Sopenharmony_ci
22e41f4b71Sopenharmony_ci1. 获取密钥别名。
23e41f4b71Sopenharmony_ci
24e41f4b71Sopenharmony_ci2. 获取待运算的数据。
25e41f4b71Sopenharmony_ci
26e41f4b71Sopenharmony_ci3. 调用[initSession](../../reference/apis-universal-keystore-kit/js-apis-huks.md#huksinitsession9)初始化密钥会话,并获取会话的句柄handle。
27e41f4b71Sopenharmony_ci
28e41f4b71Sopenharmony_ci4. 调用[finishSession](../../reference/apis-universal-keystore-kit/js-apis-huks.md#huksfinishsession9)结束密钥会话,获取哈希后的数据。
29e41f4b71Sopenharmony_ci
30e41f4b71Sopenharmony_ci
31e41f4b71Sopenharmony_ci```ts
32e41f4b71Sopenharmony_ci/*
33e41f4b71Sopenharmony_ci * 以下以HMAC密钥的Promise操作使用为例
34e41f4b71Sopenharmony_ci */
35e41f4b71Sopenharmony_ciimport { huks } from '@kit.UniversalKeystoreKit';
36e41f4b71Sopenharmony_ci
37e41f4b71Sopenharmony_cilet HmackeyAlias = 'test_HMAC';
38e41f4b71Sopenharmony_cilet handle: number;
39e41f4b71Sopenharmony_cilet plainText = '123456';
40e41f4b71Sopenharmony_cilet hashData: Uint8Array;
41e41f4b71Sopenharmony_ci
42e41f4b71Sopenharmony_cifunction StringToUint8Array(str: String) {
43e41f4b71Sopenharmony_ci  let arr: number[] = new Array();
44e41f4b71Sopenharmony_ci  for (let i = 0, j = str.length; i < j; ++i) {
45e41f4b71Sopenharmony_ci    arr.push(str.charCodeAt(i));
46e41f4b71Sopenharmony_ci  }
47e41f4b71Sopenharmony_ci  return new Uint8Array(arr);
48e41f4b71Sopenharmony_ci}
49e41f4b71Sopenharmony_ci
50e41f4b71Sopenharmony_cifunction Uint8ArrayToString(fileData: Uint8Array) {
51e41f4b71Sopenharmony_ci  let dataString = '';
52e41f4b71Sopenharmony_ci  for (let i = 0; i < fileData.length; i++) {
53e41f4b71Sopenharmony_ci    dataString += String.fromCharCode(fileData[i]);
54e41f4b71Sopenharmony_ci  }
55e41f4b71Sopenharmony_ci  return dataString;
56e41f4b71Sopenharmony_ci}
57e41f4b71Sopenharmony_ci
58e41f4b71Sopenharmony_cifunction GetHMACProperties() {
59e41f4b71Sopenharmony_ci  const properties: Array<huks.HuksParam> = [{
60e41f4b71Sopenharmony_ci    tag: huks.HuksTag.HUKS_TAG_ALGORITHM,
61e41f4b71Sopenharmony_ci    value: huks.HuksKeyAlg.HUKS_ALG_HMAC
62e41f4b71Sopenharmony_ci  }, {
63e41f4b71Sopenharmony_ci    tag: huks.HuksTag.HUKS_TAG_KEY_SIZE,
64e41f4b71Sopenharmony_ci    value: huks.HuksKeySize.HUKS_AES_KEY_SIZE_256
65e41f4b71Sopenharmony_ci  }, {
66e41f4b71Sopenharmony_ci    tag: huks.HuksTag.HUKS_TAG_PURPOSE,
67e41f4b71Sopenharmony_ci    value: huks.HuksKeyPurpose.HUKS_KEY_PURPOSE_MAC
68e41f4b71Sopenharmony_ci  }, {
69e41f4b71Sopenharmony_ci    tag: huks.HuksTag.HUKS_TAG_DIGEST,
70e41f4b71Sopenharmony_ci    value: huks.HuksKeyDigest.HUKS_DIGEST_SHA384,
71e41f4b71Sopenharmony_ci  }];
72e41f4b71Sopenharmony_ci  return properties;
73e41f4b71Sopenharmony_ci}
74e41f4b71Sopenharmony_ci
75e41f4b71Sopenharmony_ciasync function GenerateHMACKey() {
76e41f4b71Sopenharmony_ci  /*
77e41f4b71Sopenharmony_ci  * 模拟生成密钥场景
78e41f4b71Sopenharmony_ci  * 1. 确定密钥别名
79e41f4b71Sopenharmony_ci  */
80e41f4b71Sopenharmony_ci  /*
81e41f4b71Sopenharmony_ci  * 2. 获取生成密钥算法参数配置
82e41f4b71Sopenharmony_ci  */
83e41f4b71Sopenharmony_ci  let genProperties = GetHMACProperties();
84e41f4b71Sopenharmony_ci  let options: huks.HuksOptions = {
85e41f4b71Sopenharmony_ci    properties: genProperties
86e41f4b71Sopenharmony_ci  }
87e41f4b71Sopenharmony_ci  /*
88e41f4b71Sopenharmony_ci  * 3. 调用generateKeyItem
89e41f4b71Sopenharmony_ci  */
90e41f4b71Sopenharmony_ci  await huks.generateKeyItem(HmackeyAlias, options)
91e41f4b71Sopenharmony_ci    .then((data) => {
92e41f4b71Sopenharmony_ci      console.info(`promise: generate HMAC Key success`);
93e41f4b71Sopenharmony_ci    }).catch((error: Error) => {
94e41f4b71Sopenharmony_ci      console.error(`promise: generate HMAC Key failed, ${JSON.stringify(error)}`);
95e41f4b71Sopenharmony_ci    })
96e41f4b71Sopenharmony_ci}
97e41f4b71Sopenharmony_ci
98e41f4b71Sopenharmony_ciasync function HMACData() {
99e41f4b71Sopenharmony_ci  /*
100e41f4b71Sopenharmony_ci  * 模拟HMAC场景
101e41f4b71Sopenharmony_ci  * 1. 获取密钥别名
102e41f4b71Sopenharmony_ci  */
103e41f4b71Sopenharmony_ci  /*
104e41f4b71Sopenharmony_ci  * 2. 获取待哈希的数据
105e41f4b71Sopenharmony_ci  */
106e41f4b71Sopenharmony_ci  /*
107e41f4b71Sopenharmony_ci  * 3. 获取HMAC算法参数配置
108e41f4b71Sopenharmony_ci  */
109e41f4b71Sopenharmony_ci  let hmacProperties = GetHMACProperties();
110e41f4b71Sopenharmony_ci  let options: huks.HuksOptions = {
111e41f4b71Sopenharmony_ci    properties: hmacProperties,
112e41f4b71Sopenharmony_ci    inData: StringToUint8Array(plainText)
113e41f4b71Sopenharmony_ci  }
114e41f4b71Sopenharmony_ci  /*
115e41f4b71Sopenharmony_ci  * 4. 调用initSession获取handle
116e41f4b71Sopenharmony_ci  */
117e41f4b71Sopenharmony_ci  await huks.initSession(HmackeyAlias, options)
118e41f4b71Sopenharmony_ci    .then((data) => {
119e41f4b71Sopenharmony_ci      handle = data.handle;
120e41f4b71Sopenharmony_ci    }).catch((error: Error) => {
121e41f4b71Sopenharmony_ci      console.error(`promise: init EncryptData failed, ${JSON.stringify(error)}`);
122e41f4b71Sopenharmony_ci    })
123e41f4b71Sopenharmony_ci  /*
124e41f4b71Sopenharmony_ci  * 5. 调用finishSession获取HMAC的结果
125e41f4b71Sopenharmony_ci  */
126e41f4b71Sopenharmony_ci  await huks.finishSession(handle, options)
127e41f4b71Sopenharmony_ci    .then((data) => {
128e41f4b71Sopenharmony_ci      console.info(`promise: HMAC data success, data is ` + Uint8ArrayToString(data.outData as Uint8Array));
129e41f4b71Sopenharmony_ci      hashData = data.outData as Uint8Array;
130e41f4b71Sopenharmony_ci    }).catch((error: Error) => {
131e41f4b71Sopenharmony_ci      console.error(`promise: HMAC data failed, ${JSON.stringify(error)}`);
132e41f4b71Sopenharmony_ci    })
133e41f4b71Sopenharmony_ci}
134e41f4b71Sopenharmony_ci```
135