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