利用Crypto对请求参数进行MD5/AES加解密
ApiPost内置了Crypto(
https://github.com/brix/crypto-js) ,可以方便地对请求参数进行各种加解密。
MD5加密
Crypto.MD5('待加密字符串').toString()
SHA256加密
Crypto.SHA256('待加密字符串').toString()
base64加密
Crypto.enc.Base64.stringify(Crypto.enc.Utf8.parse('待加密字符串'))
base64解密
Crypto.enc.Base64.parse("待解密字符串").toString(Crypto.enc.Utf8)
AES简单加密
Crypto.AES.encrypt('待加密字符串', '秘钥').toString()
AES简单解密
Crypto.AES.decrypt('待解密字符串', '秘钥').toString(Crypto.enc.Utf8)
自定义AES加解密函数
以上示例是2个简单aes加解密方案,大部分情况下,我们需要自定义aes加解密更多的参数,比如加密模式、填充等。
const key = Crypto.enc.Utf8.parse("秘钥"); //十六位十六进制数作为密钥
const iv = Crypto.enc.Utf8.parse('偏移量'); //十六位十六进制数作为密钥偏移量
//解密方法
function Decrypt(word) {
let encryptedHexStr = Crypto.enc.Hex.parse(word);
let srcs = Crypto.enc.Base64.stringify(encryptedHexStr);
let decrypt = Crypto.AES.decrypt(srcs, key, { iv: iv, mode: Crypto.mode.CBC, padding: Crypto.pad.Pkcs7 });
let decryptedStr = decrypt.toString(Crypto.enc.Utf8);
return decryptedStr.toString();
}
//加密方法
function Encrypt(word) {
let srcs = Crypto.enc.Utf8.parse(word);
let encrypted = Crypto.AES.encrypt(srcs, key, { iv: iv, mode: Crypto.mode.CBC, padding: Crypto.pad.Pkcs7 });
return encrypted.ciphertext.toString().toUpperCase();
}
//以上方法中 mode就是加密模式,padding是填充。
请求示例
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。