1# 指定二进制数据转换对称密钥(ArkTS) 2 3### 介绍 4 5以3DES和HMAC为例,根据指定的对称密钥二进制数据,生成密钥(SymKey),即将外部或存储的二进制数据转换为算法库的密钥对象,该对象可用于后续的加解密等操作。 6 7本示例主要展示了指定二进制数据转换对称密钥(ArkTS),指定二进制数据转换3DES密钥和指定二进制数据转换HMAC密钥场景。该工程中展示的代码详细描述可查如下链接中业务扩展场景介绍部分。 8 9- [指定二进制数据转换对称密钥(ArkTS)](https://docs.openharmony.cn/pages/v5.0/zh-cn/application-dev/security/CryptoArchitectureKit/crypto-convert-binary-data-to-sym-key.md) 10 11### 效果预览 12 13| 首页效果图 | 执行结果图 | 14| ------------------------------------------------------------ | ------------------------------------------------------------ | 15| <img src="./screenshots/ConvertSymmetricKeyBinaryFormatArkTS1.png" style="zoom: 50%;" /> | <img src="./screenshots/ConvertSymmetricKeyBinaryFormatArkTS2.png" style="zoom: 50%;" /> | 16 17### 使用说明 18 191. 运行Index主界面。 202. 页面呈现上述执行结果图效果,点击不同按钮可以跳转到不同功能页面,点击跳转页面中按钮可以执行对应操作,并更新文本内容。 213. 运行测试用例ConvertSymmetricKeyBinaryFormatArkTS.test.ets文件对页面代码进行测试可以全部通过。 22 23### 工程目录 24 25``` 26entry/src/ 27 ├── main 28 │ ├── ets 29 │ │ ├── entryability 30 │ │ ├── entrybackupability 31 │ │ ├── pages 32 │ │ ├── Index.ets // 指定二进制数据转换对称密钥(ArkTS)示例代码 33 │ │ ├── 3des 34 │ │ | ├── Callback.ets 35 │ │ | ├── Sync.ets 36 │ │ ├── hmac 37 │ │ | ├── Await.ets 38 │ │ | ├── Sync.ets 39 │ ├── module.json5 40 │ └── resources 41 ├── ohosTest 42 │ ├── ets 43 │ │ └── test 44 │ │ ├── Ability.test.ets 45 │ │ ├── ConvertSymmetricKeyBinaryFormatArkTS.test.ets // 自动化测试代码 46 │ │ └── List.test.ets 47``` 48 49### 相关权限 50 51不涉及。 52 53### 依赖 54 55不涉及。 56 57### 约束与限制 58 591.本示例仅支持标准系统上运行, 支持设备:RK3568。 60 612.本示例为Stage模型,支持API14版本SDK,版本号:5.0.2.57,镜像版本号:OpenHarmony_5.0.2.58。 62 633.本示例需要使用DevEco Studio 5.0.1 Release (Build Version: 5.0.5.306, built on December 6, 2024)及以上版本才可编译运行。 64 65### 下载 66 67如需单独下载本工程,执行如下命令: 68 69```` 70git init 71git config core.sparsecheckout true 72echo code/DocsSample/Security/CryptoArchitectureKit/KeyGenerationConversion/ConvertSymmetricKeyBinaryFormatArkTS > .git/info/sparse-checkout 73git remote add origin https://gitee.com/openharmony/applications_app_samples.git 74git pull origin master 75````