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