快應(yīng)用 密碼算法

2020-08-08 15:40 更新

接口聲明

{"name": "system.cipher"}

導(dǎo)入模塊

import cipher from '@system.cipher' 
或 
const cipher = require('@system.cipher')

接口定義

cipher.rsa(OBJECT)

RSA加解密。不支持分段加密,內(nèi)容超長(zhǎng)會(huì)出錯(cuò)

參數(shù):

參數(shù)名 類型 必填 說(shuō)明
action String 加解密類型,兩個(gè)可選值:encrypt:加密,decrypt: 解密
text String 待加密或解密的文本內(nèi)容。待加密的文本內(nèi)容應(yīng)該是一段普通文本,待解密的文本內(nèi)容應(yīng)該是經(jīng)過(guò)base64編碼的一段二進(jìn)制值。base64編碼使用默認(rèn)風(fēng)格,下同
key String 加密或解密使用到的RSA密鑰,經(jīng)過(guò)base64編碼后生成的字符串。加密時(shí)key為公鑰,解密時(shí)key為私鑰
transformation String RSA算法的填充項(xiàng),默認(rèn)為"RSA/None/OAEPwithSHA-256andMGF1Padding"
success Function 成功回調(diào)
fail Function 失敗回調(diào)
complete Function 執(zhí)行結(jié)束后的回調(diào)
success返回值:
參數(shù)名 類型 說(shuō)明
text String 經(jīng)過(guò)加密或解密后生成的文本內(nèi)容。加密后內(nèi)容是經(jīng)過(guò)base64編碼的一段二進(jìn)制值,解密后內(nèi)容是一段普通文本。如果解密后的內(nèi)容不能轉(zhuǎn)化為utf-8字符串會(huì)出錯(cuò)
fail返回錯(cuò)誤代碼
錯(cuò)誤碼 說(shuō)明
202 輸入?yún)?shù)錯(cuò)誤。

示例:

//加密
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編碼后的一段二進(jìn)制值,解密后是文本內(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}`)
  }
})

cipher.aes(OBJECT)

AES 加解密。支持分段加密

參數(shù):

參數(shù)名類型必填說(shuō)明
actionString加解密類型,兩個(gè)可選值:encrypt:加密,decrypt: 解密
textString待加密或解密的文本內(nèi)容。待加密的文本內(nèi)容應(yīng)該是一段普通文本。待解密的文本內(nèi)容應(yīng)該是經(jīng)過(guò) base64 編碼的一段二進(jìn)制值。base64 編碼使用默認(rèn)風(fēng)格,下同
keyString加密或解密使用到的密鑰,經(jīng)過(guò) base64 編碼后生成的字符串。
transformationStringAES 算法的加密模式和填充項(xiàng),默認(rèn)為"AES/CBC/PKCS5Padding"
ivStringAES加解密的初始向量,經(jīng)過(guò)base64編碼后的字符串,默認(rèn)值為key值
ivOffsetintAES加解密的初始向量偏移,默認(rèn)值為0
ivLenintAES加解密的初始向量字節(jié)長(zhǎng)度,默認(rèn)值為16
successFunction成功回調(diào)
failFunction失敗回調(diào)
completeFunction執(zhí)行結(jié)束后的回調(diào)
success 返回值:
參數(shù)名類型說(shuō)明
textString經(jīng)過(guò)加密或解密后生成的文本內(nèi)容。加密后內(nèi)容是經(jīng)過(guò) base64 編碼的一段二進(jìn)制值,解密后內(nèi)容是一段普通文本。如果解密后的內(nèi)容不能轉(zhuǎn)化為 utf-8 字符串會(huì)出錯(cuò)(CODE:200)
fail 返回錯(cuò)誤代碼
錯(cuò)誤碼說(shuō)明
200一般性錯(cuò)誤,在加解密出錯(cuò)時(shí)會(huì)返回此錯(cuò)誤
202參數(shù)錯(cuò)誤

示例:

//加密
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編碼后的一段二進(jìn)制值
  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)
    })
  }
})

后臺(tái)運(yùn)行限制

無(wú)限制。后臺(tái)運(yùn)行詳細(xì)用法參見(jiàn) 后臺(tái)運(yùn)行腳本


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)