密码算法 1000+

接口声明

  1. { "name": "system.cipher" }

导入模块

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

接口定义

cipher.rsa(OBJECT)

RSA 加解密。不支持分段加密,内容超长会出错

参数:

参数名类型必填说明
actionString加解密类型,两个可选值:encrypt:加密,decrypt: 解密
textString待加密或解密的文本内容。待加密的文本内容应该是一段普通文本,长度不能超过 keySize / 8 - 66,其中 keySize 是秘钥的长度(例如秘钥长度为 1024 时,text 不能超过 62 个字节)。待解密的文本内容应该是经过 base64 编码的一段二进制值。base64 编码使用默认风格,下同
keyString加密或解密使用到的 RSA 密钥,经过 base64 编码后生成的字符串。加密时 key 为公钥,解密时 key 为私钥
transformationStringRSA 算法的填充项,默认为"RSA/None/OAEPwithSHA-256andMGF1Padding"
successFunction成功回调
failFunction失败回调
completeFunction执行结束后的回调
success 返回值:
参数名类型说明
textString经过加密或解密后生成的文本内容。加密后内容是经过 base64 编码的一段二进制值,解密后内容是一段普通文本。如果解密后的内容不能转化为 utf-8 字符串会出错
fail 返回错误代码
错误码说明
202输入参数错误。

示例:

  1. //加密
  2. cipher.rsa({
  3. action: 'encrypt',
  4. //待加密的文本内容
  5. text: 'hello',
  6. //base64编码后的加密公钥
  7. key:
  8. 'MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDc7GR2MrfAoefES+wrs1ns2afT\n' +
  9. 'eJXSfIkEHfPXG9fVFjaws1ho4KcZfsxlA0+SXvc83f2SVGCuzULmM2lxxRCtcUN/\n' +
  10. 'h7SoaYEeluhqFimL2AEjfSwINHCLqObJkcjCfoZpE1JCehPiDOJsyT50Auc08h/4\n' +
  11. 'jHQfanyC1nc62LqUCQIDAQAB',
  12. success: function(data) {
  13. console.log(`handling success: ${data.text}`)
  14. },
  15. fail: function(data, code) {
  16. console.log(`### cipher.rsa fail ### ${code}: ${data}`)
  17. }
  18. })
  19. //解密:
  20. cipher.rsa({
  21. action: 'decrypt',
  22. //待解密的内容,是base64编码后的一段二进制值,解密后是文本内容“hello”
  23. text:
  24. 'CUg3tTxTIdpCfreIxIBdws3uhd5qXLwcrVl3XDnQzZFVHyjVVCDHS16rjopaZ4C5xU2Tc8mSDzt7\n' +
  25. 'gp9vBfSwi7bMtSUvXG18DlncsKJFDkJpS5t0PkpS9YrJXrY80Gpe+ME6+6dN9bjgqMljbitDdBRf\n' +
  26. 'S/ZWNI4Q8Q0suNjNkGU=',
  27. //base64编码后的解密私钥
  28. key:
  29. 'MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBANzsZHYyt8Ch58RL\n' +
  30. '7CuzWezZp9N4ldJ8iQQd89cb19UWNrCzWGjgpxl+zGUDT5Je9zzd/ZJUYK7NQuYz\n' +
  31. 'aXHFEK1xQ3+HtKhpgR6W6GoWKYvYASN9LAg0cIuo5smRyMJ+hmkTUkJ6E+IM4mzJ\n' +
  32. 'PnQC5zTyH/iMdB9qfILWdzrYupQJAgMBAAECgYEAkibhH0DWR13U0gvYJeD08Lfd\n' +
  33. 'Sw1PMHyquEqIcho9Yv7bF3LOXjOg2EEGPx09mvuwXFgP1Kp1e67XPytr6pQQPzK7\n' +
  34. 'XAPcLPx80R/ZjZs8vNFndDOd1HgD3vSVmYQarNzmKi72tOUWMPevsaFXPHo6Xx3X\n' +
  35. '8x0wYb7XuBsQguRctTECQQD7GWX3JUiyo562iVrpTDPOXsrUxmzCrgz2OZildxMd\n' +
  36. 'Pp/PkyDrx7mEXTpk4K/XnQJ3GpJNi2iDSxDuPSAeJ/aPAkEA4Tw4+1Z43S/xH3C3\n' +
  37. 'nfulYBNyB4si6KEUuC0krcC1pDJ21Gd12efKo5VF8SaJI1ZUQOzguV+dqNsB/JUY\n' +
  38. 'OFfX5wJAB1dKv9r7MR3Peg6x9bggm5vx2h6i914XSuuMJupASM6X5X2rrLj+F3yS\n' +
  39. 'RHi9K1SPyeOg+1tkBtKfABgRZFBOyQJAbuTivUSe73AqTKuHjB4ZF0ubqgEkJ9sf\n' +
  40. 'Q2rekzm9dOFvxjZGPQo1qALX09qATMi1ZN376ukby8ZAnSafLSZ64wJBAM2V37go\n' +
  41. 'Sj44HF76ksRow8gecuQm48NCTGAGTicXg8riKog2GC9y8pMNHAezoR9wXJF7kk+k\n' +
  42. 'lz5cHyoMZ9mcd30=',
  43. success: function(data) {
  44. console.log(`handling success: ${data.text}`)
  45. },
  46. fail: function(data, code) {
  47. console.log(`### cipher.rsa fail ### ${code}: ${data}`)
  48. }
  49. })

后台运行限制

无限制。后台运行详细用法参见后台运行 脚本