前端如何进行 AES 加密 / 解密

信息安全一直是大家关注点比较高问题, 信息泄露, 请求篡改, 报文拦截等层出不穷.
如何才能让请求 和 返回的数据更加安全?
今天介绍其中一种 加密 / 解密 的方法 使用插件Crypto.JS ( AES )

需求是:websocket聊天信息加密

keys:前后端共同制定的公钥

params: 加密字段

第一步: 安装

npm install --save_dev crypto-js

第二步: 全局引用

// 导入 crypto-js 包 
import cryptoJS from 'crypto-js/crypto-js'
//把AES加密vue原型里
Vue.prototype.$cryptoJS = cryptoJS;

第三步: 使用

加密

encryptionAES (params) {
    let keys = '' , encryptorStr = '';
    keys = this.$cryptoJS.enc.Utf8.parse("后端定的加密公钥");
    params = this.$cryptoJS.enc.Utf8.parse(params);
    // 开始加密
    encryptorStr = this.$cryptoJS.AES.encrypt(
        params, 
        keys, 
        { 
            mode: this.$cryptoJS.mode.ECB, 
            padding: this.$cryptoJS.pad.Pkcs7
        }
    );
    encryptorStr = String(encryptorStr); //之将加密后的转换成 字符串, 解密成功
    //返回 加密后的 字符串
    return encryptorStr;
}

解密

decryptAES (params) { 
    let keys = '' , decryptStr = '';
    keys = this.$cryptoJS.enc.Utf8.parse("后端定的加密公钥");
    // 开始解密
    decryptStr = this.$cryptoJS.AES.decrypt(
        params, 
        keys, 
        {
            mode: this.$cryptoJS.mode.ECB,
            padding: this.$cryptoJS.pad.Pkcs7
        }
    );
    decryptStr = this.$cryptoJS.enc.Utf8.stringify(decryptStr).toString();
    //返回 解密后的 字符串
    return decryptStr;
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值