• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# @system.cipher (加密算法)
2
3<!--Kit: Crypto Architecture Kit-->
4<!--Subsystem: Security-->
5<!--Owner: @zxz--3-->
6<!--Designer: @lanming-->
7<!--Tester: @PAFT-->
8<!--Adviser: @zengyawen-->
9
10> **说明:**
11>
12> 本模块首批接口从API version 3开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
13>
14> 从API version 9开始废弃, 建议使用[@ohos.security.cryptoFramework的Cipher](js-apis-cryptoFramework.md#cipher)替代。
15
16## 导入模块
17
18
19```js
20import cipher from '@system.cipher';
21```
22
23## CipherResponse
24
25调用cipher接口后,返回的内容。
26
27**系统能力**:SystemCapability.Security.Cipher
28
29| 名称 | 类型   | 只读 | 可选 |说明         |
30| ------ | ------ | ---- | ---- | ------------ |
31| text   | string | 否   | 否   | 返回的内容。 |
32
33
34## CipherRsaOptions
35
36调用cipher rsa方法时,传入的参数。
37
38**系统能力**:SystemCapability.Security.Cipher
39
40| 名称         | 类型                                 | 必填 | 说明                                                         |
41| -------------- | ------------------------------------ | ---- | ------------------------------------------------------------ |
42| action         | string                               | 是   | 加密类型,可选项有:<br/>1. encrypt 加密;<br/>2. decrypt 解密。 |
43| text           | string                               | 是   | 待加密或解密的文本内容。待加密的文本内容应该是一段普通文本,长度不能超过 keySize / 8 - 66,其中 keySize 是密钥的长度(例如密钥长度为 1024 时,text 不能超过 62 个字节)。待解密的文本内容应该是经过 base64 编码的一段二进制值。base64 编码使用默认风格。 |
44| key            | string                               | 是   | 加密的密钥,RSA的密钥。加密时key为公钥,解密时key为私钥。      |
45| transformation | string                               | 否   | RSA算法的填充项,默认为RSA/None/OAEPWithSHA256AndMGF1Padding。 |
46| success        | (data: [CipherResponse](#cipherresponse)) => void       | 否   | 接口调用成功的回调函数。                                     |
47| fail           | (data: string, code: number) => void | 否   | 接口调用失败的回调函数。                                     |
48| complete       | () => void                           | 否   | 接口调用结束的回调函数。                                     |
49
50## CipherAesOptions
51
52调用cipher aes方法时,传入的参数。
53
54**系统能力**:SystemCapability.Security.Cipher
55
56| 名称         | 类型                                 | 必填 | 说明                                                         |
57| -------------- | ------------------------------------ | ---- | ------------------------------------------------------------ |
58| action         | string                               | 是   | 加密类型,可选项有:<br/>1. encrypt 加密;<br/>2. decrypt 解密。 |
59| text           | string                               | 是   | 待加密或解密的文本内容。待加密的文本内容应该是一段普通文本。待解密的文本内容应该是经过 base64 编码的一段二进制值。base64 编码使用默认风格。 |
60| key            | string                               | 是   | 加密或解密使用到的密钥,经过 base64 编码后生成的字符串。 |
61| transformation | string                               | 否   | AES算法的加密模式和填充项,默认AES/CBC/PKCS5Padding。          |
62| iv             | string                               | 否   | AES加解密的初始向量,经过base64编码后的字符串,默认值为key值。 |
63| ivOffset       | string                               | 否   | AES加解密的初始向量偏移,默认值0,仅支持0。                  |
64| ivLen          | string                               | 否   | AES加解密的初始向量字节长度,当前为预留字段,默认值16,仅支持16。 |
65| success        | (data: [CipherResponse](#cipherresponse)) => void       | 否   | 接口调用成功的回调函数。                                     |
66| fail           | (data: string, code: number) => void | 否   | 接口调用失败的回调函数。                                     |
67| complete       | () => void                           | 否   | 接口调用结束的回调函数。                                     |
68
69## cipher.rsa
70
71rsa(options: CipherRsaOptions): void
72
73RSA 算法加解密。
74
75**系统能力:** SystemCapability.Security.Cipher
76
77**参数:**
78
79| 参数名 | 类型 | 必填 | 说明 |
80| -------- | -------- | -------- | -------- |
81| options | [CipherRsaOptions](#cipherrsaoptions) | 是 | rsa加解密需要设置的参数。 |
82
83**示例:**
84
85```js
86export default {
87  rsa() {
88    cipher.rsa({
89      //加密。
90      action: 'encrypt',
91      //待加密的文本内容。
92      text: 'hello',
93      //base64编码后的加密公钥。
94      key:
95     'MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCx414QSP3RsYWYzf9mkBMiBAXo\n' +
96     '6S7Lpva1fKlcuVxjoFC1iMnzD4mC0uiL4k5MNi43J64c7dbqi3qAJjdAtuwQ6NZJ\n' +
97     '+Enz0RzmVFh/4yk6lmqRzuEFQqhQqSZzaLq6sq2N2G0Sv2Xl3sLvqAfe2HNm2oBw\n' +
98     'jBpApTJ3TeneOo6Z5QIDAQAB',
99      success: function(data) {
100        console.log(`handling success:${data.text}`);
101      },
102      fail: function(data, code) {
103        console.log(`### cipher.rsa encrypt fail ### ${code}:${data}`);
104      },
105      complete: function() {
106        console.log(`operation complete!`);
107      }
108      });
109      cipher.rsa({
110        //解密:
111        action: 'decrypt',
112        //待解密的内容,是base64编码后的一段二进制值,解密后是文本内容“hello”。
113        text:
114       'EPeCFPib6ayKbA0M6oSywARvFZ8dFYfjQv3nY8ikZGtS9UHq2sLPvAfpeIzggSiCxqbWeCftP1XQ\n' +
115       'Sa+jEpzFlT1qoSTunBbrYzugPTajIJDTg6R1IRsF/J+mmakn0POVPvi4jCo9wqavB324Bx0Wipnc\n' +
116       'EU5WO0oBHo5l4x6dTpU=',
117         //base64编码后的解密私钥。
118         key:
119        'MIICXgIBAAKBgQCx414QSP3RsYWYzf9mkBMiBAXo6S7Lpva1fKlcuVxjoFC1iMnz\n' +
120        'D4mC0uiL4k5MNi43J64c7dbqi3qAJjdAtuwQ6NZJ+Enz0RzmVFh/4yk6lmqRzuEF\n' +
121        'QqhQqSZzaLq6sq2N2G0Sv2Xl3sLvqAfe2HNm2oBwjBpApTJ3TeneOo6Z5QIDAQAB\n' +
122        'AoGBAKPNtoRQcklxqo+2wQP0j2m3Qqnib1DggjVEgb/8f/LNYQSI3U2QdROemryU\n' +
123        'u3y6N3xacZ359PktTrRKfH5+8ohmHGhIuPAnefp6bLvAFUcl4t1xm74Cow62Kyw3\n' +
124        'aSbmuTG98dxPA1sXD0jiprdtsq2wQ9CoKNyY7/d/pKoqxNuBAkEA4GytZ60NCTj9\n' +
125        'w24jACFeko5YqCFY/TTLoc4SQvWtFMnimRPclLZhtUIK0P8dib71UFedx+AxklgL\n' +
126        'A5gjcfo+2QJBAMrqiwyCh3OQ5DhyRPDwt87x1/jg5fy4hhete2ufSf2FoQCVqO+w\n' +
127        'PKoljdXmJeS6rGgzGibstuHLrP3tcIho4+0CQD3ZFWzF/xq0jxKlrpWhnJuNCRfE\n' +
128        'oO6e9yNvVA8J/5oEDSOcmqSNIp4+RhbUx8InUxnCG6Ryv5aSFu71pYcKrPkCQQCL\n' +
129        'RUGcm3ZGTnslduB0knNF+V2ndwzDUQ7P74UXT+PjurTPhujFYiuxCEd6ORVnEOzG\n' +
130        'M9TORIgdH8MjIbWsGnndAkEAw9yURDaorE8IYPLF2IEn09g1uzvWPs3phDb6smVx\n' +
131        '8GfqIdUNf+aCG5TZK/kXBF1sqcsi7jXMAf4jBlejVbSVZg==',
132         success: function(data) {
133           console.log(`handling success:${data.text}`);
134         },
135         fail: function(data, code) {
136           console.log(`### cipher.rsa decrypt fail ### ${code}:${data}`);
137         },
138         complete: function() {
139           console.log(`operation complete!`);
140         }
141       });
142   }
143}
144```
145
146
147## cipher.aes
148
149aes(options: CipherAesOptions): void
150
151AES 算法加解密。
152
153**系统能力:** SystemCapability.Security.Cipher
154
155**参数:**
156
157| 参数名 | 类型 | 必填 | 说明 |
158| -------- | -------- | -------- | -------- |
159| options | [CipherAesOptions](#cipheraesoptions) | 是 | aes加解密需要设置的参数。 |
160
161**示例:**
162
163```js
164export default {
165  aes() {
166    cipher.aes({
167      //加密。
168      action: 'encrypt',
169      //待加密的文本内容。
170      text: 'hello',
171      //base64编码后的密钥。
172      key: 'NDM5Qjk2UjAzMEE0NzVCRjlFMkQwQkVGOFc1NkM1QkQ=',
173      transformation: 'AES/CBC/PKCS5Padding',
174      ivOffset: '0',
175      ivLen: '16',
176      success: function(data) {
177        console.log(`handling success:${data.text}`);
178        },
179      fail: function(data, code) {
180        console.log(`### cipher.aes encrypt fail ### ${code}:${data}`);
181        },
182      complete: function() {
183        console.log(`operation complete!`);
184      }
185    });
186    cipher.aes({
187      //解密:
188      action: 'decrypt',
189      //待解密的内容,是base64编码后的一段二进制值。
190      text: '1o0kf2HXwLxHkSh5W5NhzA==',
191       //base64编码后的密钥。
192       key: 'NDM5Qjk2UjAzMEE0NzVCRjlFMkQwQkVGOFc1NkM1QkQ=',
193       transformation: 'AES/CBC/PKCS5Padding',
194       ivOffset: '0',
195       ivLen: '16',
196       success: function(data) {
197         console.log(`handling success:${data.text}`);
198        },
199       fail: function(data, code) {
200         console.log(`### cipher.aes decrypt fail ### ${code}:${data}`);
201       },
202       complete: function() {
203         console.log(`operation complete!`);
204        }
205     });
206  }
207}
208
209```
210
211