基于VUE的前端crypto-js aes加密与解密

第一步: npm install crypto-js --savejavascript

第二步:在utils文件夹下新建secret.js文件,封装公共方法。java

密钥可由服务端返回算法

const CryptoJS = require('crypto-js');  //引用AES源码js    
const key = CryptoJS.enc.Utf8.parse("1234123412ABCDEF");  //十六位十六进制数做为密钥
const iv = CryptoJS.enc.Utf8.parse('ABCDEF1234123412');   //十六位十六进制数做为密钥偏移量

//加密方法
export function Encrypt(word){
  let srcs = CryptoJS.enc.Utf8.parse(word);
  let encrypted = CryptoJS.AES.encrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 });
  return encrypted.ciphertext.toString().toUpperCase();
}
//解密方法
export function Decrypt(word){
  let encryptedHexStr = CryptoJS.enc.Hex.parse(word);
  let srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
  let decrypt = CryptoJS.AES.decrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 });
  let decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
  return decryptedStr.toString();
}

第三步:使用引用npm

1.加密页面ui

<script>
import { Encrypt } from '../../utils/secret.js'
export default {
   created(){
      this.encryptionName = Encrypt(this.username) // 加密用户名
      this.getList()
   }
}
</script>

2.解密页面this

<script>
import { Decrypt } from '../../utils/secret.js'
export default {
   created(){
      this.encryptionName = Decrypt(this.username) // 解密用户名
   }
}
</script>

完成!加密

原理实现推荐这篇文章:AES加密算法的详细介绍与实现.net

相关文章
相关标签/搜索