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