W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
{"name": "system.cipher"}
import cipher from '@system.cipher'
或
const cipher = require('@system.cipher')
RSA加解密。不支持分段加密,內(nèi)容超長會出錯
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
action | String | 是 | 加解密類型,兩個可選值:encrypt:加密,decrypt: 解密 |
text | String | 是 | 待加密或解密的文本內(nèi)容。待加密的文本內(nèi)容應(yīng)該是一段普通文本,待解密的文本內(nèi)容應(yīng)該是經(jīng)過base64編碼的一段二進制值。base64編碼使用默認風格,下同 |
key | String | 是 | 加密或解密使用到的RSA密鑰,經(jīng)過base64編碼后生成的字符串。加密時key為公鑰,解密時key為私鑰 |
transformation | String | 否 | RSA算法的填充項,默認為"RSA/None/OAEPwithSHA-256andMGF1Padding" |
success | Function | 否 | 成功回調(diào) |
fail | Function | 否 | 失敗回調(diào) |
complete | Function | 否 | 執(zhí)行結(jié)束后的回調(diào) |
參數(shù)名 | 類型 | 說明 |
---|---|---|
text | String | 經(jīng)過加密或解密后生成的文本內(nèi)容。加密后內(nèi)容是經(jīng)過base64編碼的一段二進制值,解密后內(nèi)容是一段普通文本。如果解密后的內(nèi)容不能轉(zhuǎn)化為utf-8字符串會出錯 |
錯誤碼 | 說明 |
---|---|
202 | 輸入?yún)?shù)錯誤。 |
//加密
cipher.rsa({
action: 'encrypt',
//待加密的文本內(nèi)容
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',
//待解密的內(nèi)容,是base64編碼后的一段二進制值,解密后是文本內(nèi)容“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}`)
}
})
AES 加解密。支持分段加密
參數(shù)名 | 類型 | 必填 | 說明 |
---|---|---|---|
action | String | 是 | 加解密類型,兩個可選值:encrypt:加密,decrypt: 解密 |
text | String | 是 | 待加密或解密的文本內(nèi)容。待加密的文本內(nèi)容應(yīng)該是一段普通文本。待解密的文本內(nèi)容應(yīng)該是經(jīng)過 base64 編碼的一段二進制值。base64 編碼使用默認風格,下同 |
key | String | 是 | 加密或解密使用到的密鑰,經(jīng)過 base64 編碼后生成的字符串。 |
transformation | String | 否 | AES 算法的加密模式和填充項,默認為"AES/CBC/PKCS5Padding" |
iv | String | 否 | AES加解密的初始向量,經(jīng)過base64編碼后的字符串,默認值為key值 |
ivOffset | int | 否 | AES加解密的初始向量偏移,默認值為0 |
ivLen | int | 否 | AES加解密的初始向量字節(jié)長度,默認值為16 |
success | Function | 否 | 成功回調(diào) |
fail | Function | 否 | 失敗回調(diào) |
complete | Function | 否 | 執(zhí)行結(jié)束后的回調(diào) |
參數(shù)名 | 類型 | 說明 |
---|---|---|
text | String | 經(jīng)過加密或解密后生成的文本內(nèi)容。加密后內(nèi)容是經(jīng)過 base64 編碼的一段二進制值,解密后內(nèi)容是一段普通文本。如果解密后的內(nèi)容不能轉(zhuǎn)化為 utf-8 字符串會出錯(CODE:200) |
錯誤碼 | 說明 |
---|---|
200 | 一般性錯誤,在加解密出錯時會返回此錯誤 |
202 | 參數(shù)錯誤 |
//加密
cipher.aes({
action: 'encrypt',
//待加密的文本內(nèi)容
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',
//待解密的內(nèi)容,是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)
})
}
})
無限制。后臺運行詳細用法參見 后臺運行腳本。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: