# 密码算法 cipher
# 接口声明
{ "name": "system.cipher" }
1
# 导入模块
import cipher from '@system.cipher' 或 const cipher = require('@system.cipher')
1
# 接口定义
# cipher.rsa(OBJECT)
RSA 加解密。不支持分段加密,内容超长会出错
# 参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
action | String | 是 | 加解密类型,两个可选值:encrypt:加密,decrypt:解密 |
text | String | 是 | 待加密或解密的文本内容。待加密的文本内容应该是一段普通文本,长度不能超过 keySize / 8 - 66,其中 keySize 是秘钥的长度(例如秘钥长度为 1024 时,text 不能超过 62 个字节)。待解密的文本内容应该是经过 base64 编码的一段二进制值。base64 编码使用默认风格,下同 |
key | String | 是 | 加密或解密使用到的 RSA 密钥(仅支持PKCS#8 ),经过 base64 编码后生成的字符串。加密时 key 为公钥,解密时 key 为私钥 |
transformation | String | 否 | RSA 算法的填充项,默认为"RSA/None/OAEPwithSHA-256andMGF1Padding" |
success | Function | 否 | 成功回调 |
fail | Function | 否 | 失败回调 |
complete | Function | 否 | 执行结束后的回调 |
# success 返回值:
参数名 | 类型 | 说明 |
---|---|---|
text | String | 经过加密或解密后生成的文本内容。加密后内容是经过 base64 编码的一段二进制值,解密后内容是一段普通文本。如果解密后的内容不能转化为 utf-8 字符串会出错 |
# fail 返回错误代码
错误码 | 说明 |
---|---|
202 | 输入参数错误。 |
# 示例:
//加密
cipher.rsa({
action: 'encrypt',
//待加密的文本内容
text: 'hello',
//base64编码后的加密公钥
key:
'MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDc7GR2MrfAoefES+wrs1ns2afT\n' +
'eJXSfIkEHfPXG9fVFjaws1ho4KcZfsxlA0+SXvc83f2SVGCuzULmM2lxxRCtcUN/\n' +
'h7SoaYEeluhqFimL2AEjfSwINHCLqObJkcjCfoZpE1JCehPiDOJsyT50Auc08h/4\n' +
'jHQfanyC1nc62LqUCQIDAQAB',
success: function(data) {
console.log(`handling success: ${data.text}`)
},
fail: function(data, code) {
console.log(`### cipher.rsa fail ### ${code}: ${data}`)
}
})
//解密:
cipher.rsa({
action: 'decrypt',
//待解密的内容,是base64编码后的一段二进制值,解密后是文本内容“hello”
text:
'CUg3tTxTIdpCfreIxIBdws3uhd5qXLwcrVl3XDnQzZFVHyjVVCDHS16rjopaZ4C5xU2Tc8mSDzt7\n' +
'gp9vBfSwi7bMtSUvXG18DlncsKJFDkJpS5t0PkpS9YrJXrY80Gpe+ME6+6dN9bjgqMljbitDdBRf\n' +
'S/ZWNI4Q8Q0suNjNkGU=',
//base64编码后的解密私钥
key:
'MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBANzsZHYyt8Ch58RL\n' +
'7CuzWezZp9N4ldJ8iQQd89cb19UWNrCzWGjgpxl+zGUDT5Je9zzd/ZJUYK7NQuYz\n' +
'aXHFEK1xQ3+HtKhpgR6W6GoWKYvYASN9LAg0cIuo5smRyMJ+hmkTUkJ6E+IM4mzJ\n' +
'PnQC5zTyH/iMdB9qfILWdzrYupQJAgMBAAECgYEAkibhH0DWR13U0gvYJeD08Lfd\n' +
'Sw1PMHyquEqIcho9Yv7bF3LOXjOg2EEGPx09mvuwXFgP1Kp1e67XPytr6pQQPzK7\n' +
'XAPcLPx80R/ZjZs8vNFndDOd1HgD3vSVmYQarNzmKi72tOUWMPevsaFXPHo6Xx3X\n' +
'8x0wYb7XuBsQguRctTECQQD7GWX3JUiyo562iVrpTDPOXsrUxmzCrgz2OZildxMd\n' +
'Pp/PkyDrx7mEXTpk4K/XnQJ3GpJNi2iDSxDuPSAeJ/aPAkEA4Tw4+1Z43S/xH3C3\n' +
'nfulYBNyB4si6KEUuC0krcC1pDJ21Gd12efKo5VF8SaJI1ZUQOzguV+dqNsB/JUY\n' +
'OFfX5wJAB1dKv9r7MR3Peg6x9bggm5vx2h6i914XSuuMJupASM6X5X2rrLj+F3yS\n' +
'RHi9K1SPyeOg+1tkBtKfABgRZFBOyQJAbuTivUSe73AqTKuHjB4ZF0ubqgEkJ9sf\n' +
'Q2rekzm9dOFvxjZGPQo1qALX09qATMi1ZN376ukby8ZAnSafLSZ64wJBAM2V37go\n' +
'Sj44HF76ksRow8gecuQm48NCTGAGTicXg8riKog2GC9y8pMNHAezoR9wXJF7kk+k\n' +
'lz5cHyoMZ9mcd30=',
success: function(data) {
console.log(`handling success: ${data.text}`)
},
fail: function(data, code) {
console.log(`### cipher.rsa fail ### ${code}: ${data}`)
}
})
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# cipher.aes(OBJECT)
AES 加解密。支持分段加密
# 参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
action | String | 是 | 加解密类型,两个可选值:encrypt:加密,decrypt:解密 |
text | String | 是 | 待加密或解密的文本内容。待加密的文本内容应该是一段普通文本。待解密的文本内容应该是经过 base64 编码的一段二进制值。base64 编码使用默认风格,下同 |
key | String | 是 | 加密或解密使用到的密钥,经过 base64 编码后生成的字符串。 |
transformation | String | 否 | AES 算法的加密模式和填充项,默认为"AES/CBC/PKCS5Padding" |
iv | String | 否 | AES 加解密的初始向量,经过 base64 编码后的字符串,默认值为 key 值 |
ivOffset | Integer | 否 | AES 加解密的初始向量偏移,默认值为 0 |
ivLen | Integer | 否 | AES 加解密的初始向量字节长度,默认值为 16 |
success | Function | 否 | 成功回调 |
fail | Function | 否 | 失败回调 |
complete | Function | 否 | 执行结束后的回调 |
# success 返回值:
参数名 | 类型 | 说明 |
---|---|---|
text | String | 经过加密或解密后生成的文本内容。加密后内容是经过 base64 编码的一段二进制值,解密后内容是一段普通文本。如果解密后的内容不能转化为 utf-8 字符串会出错(CODE:200) |
# fail 返回错误代码
错误码 | 说明 |
---|---|
200 | 一般性错误,在加解密出错时会返回此错误 |
202 | 参数错误 |
# 示例:
//加密
cipher.aes({
action: 'encrypt',
//待加密的文本内容
text: 'hello',
//base64编码后的密钥
key: 'NDM5Qjk2UjAzMEE0NzVCRjlFMkQwQkVGOFc1NkM1QkQ=',
transformation: 'AES/CBC/PKCS5Padding',
ivOffset: 0,
ivLen: 16,
success: data => {
console.log(`handling success: ${data.text}`)
},
fail: (data, code) => {
console.log(`### cipher.aes fail ### ${code}: ${data}`)
}
})
//解密:
cipher.aes({
action: 'decrypt',
//待解密的内容,是base64编码后的一段二进制值
text:
'CUg3tTxTIdpCfreIxIBdws3uhd5qXLwcrVl3XDnQzZFVHyjVVCDHS16rjopaZ4C5xU2Tc8mSDzt7\n' +
'gp9vBfSwi7bMtSUvXG18DlncsKJFDkJpS5t0PkpS9YrJXrY80Gpe+ME6+6dN9bjgqMljbitDdBRf\n' +
'S/ZWNI4Q8Q0suNjNkGU=',
//base64编码后的密钥
key: 'NDM5Qjk2UjAzMEE0NzVCRjlFMkQwQkVGOFc1NkM1QkQ=',
transformation: 'AES/CBC/PKCS5Padding',
ivOffset: 0,
ivLen: 16,
success: data => {
this.dealTxt = data.text
},
fail: (data, code) => {
prompt.showToast({
message: '解密失败, code=' + code + ':' + data
})
}
})
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# cipher.hash(OBJECT)
hash 加密
# 参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
algorithm | String | 是 | 加密算法,可选md5 ,sha256 |
content | Buffer | String | 是 | 加密内容 |
# 返回值:
类型 | 说明 |
---|---|
String | hash加密算法的结果,参数错误返回空字符串 |
# 示例:
const res = cipher.hash({
algorithm: 'md5',
content: 'hello'
})
console.log(res)
1
2
3
4
5
2
3
4
5
←
→