前端对称加密

cnpm install crypto-js --save
建utils文件夹:
secret.js

const CryptoJS = require('crypto-js');  //引用AES源码js

const key = CryptoJS.enc.Utf8.parse("1234123412ABCDEF");  //十六位十六进制数作为密钥
const iv = CryptoJS.enc.Utf8.parse('ABCDEF1234123412');   //十六位十六进制数作为密钥偏移量

//解密方法
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();
}

//加密方法
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 default {
  Decrypt,
  Encrypt
}

上面的代码中的 key 是密钥 ,iv 是密钥偏移量,这个一般是接口返回的,为了方便,我们这里就直接在这里定义了。

值得注意的是密钥的长度,由于对称解密使用的算法是 AES-128-CBC算法,数据采用 PKCS#7 填充 , 因此这里的 key 需要为16位!

接着我们定义了 解密方法Decrypt 和 加密方法 Encrypt ,最后通过 export default 将其暴露出去,方便在需要的时候进行引入~

ok,核心代码就这么多,是不是很简单啊,其实也么有你想的那么复杂哈,剩下的就是展示一下如何使用咯~

home.vue

<!--  -->
<template>
  <div class="wrapper">
    <!--加密-->
    <div class="example-box">
      <div class="title">加密示例</div>
      <p class="msg">明文:{{ msg }}</p>
      <button class="encrypt-btn" @click="encrypt">加密</button>
      <p class="msg">{{ encryptMsg }}</p>
    </div>
    <!--解密-->
    <div class="example-box">
      <div class="title">解密示例</div>
      <p class="msg">密文:{{ userInfo }}</p>
      <button class="encrypt-btn" @click="decrypt">解密</button>
      <p class="msg">{{ decryptMsg }}</p>
    </div>
  </div>
</template>

<script>
import secret from "../utils/secret";
// import userInfo from "../utils/mock";
import { Decrypt, Encrypt } from "../utils/secret";
export default {
  data() {
    return {
      msg: "This is a clear text",
      encryptMsg: "",
      userInfo: "",
      decryptMsg: ""
    };
  },

  methods: {
    encrypt() {
      this.encryptMsg = "密文:" + secret.Encrypt(this.msg);
      this.userInfo = secret.Encrypt(this.msg);
    },
    decrypt() {
      this.decryptMsg = "明文:" + secret.Decrypt(this.userInfo);
    }
  }
};
</script>
<style lang='scss' scoped>
</style>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值