Vue项目中实现AES加密解密

在前端开发中,保护用户数据的安全性至关重要。AES(高级加密标准)作为一种广泛使用的对称加密算法,因其高效性和安全性而受到青睐。本文将介绍如何在Vue项目中实现AES加密解密,包括ECB和CBC两种模式。

环境搭建

在Vue项目中使用AES加密解密功能之前,需要先安装crypto-js库。通过执行以下命令,可以轻松地将crypto-js添加到项目中:

npm install crypto-js --save-dev

封装AES加密解密方法

接下来,我们将在Vue项目的util目录下创建一个名为aes.js的文件,用于封装AES加密解密的方法。

ECB模式

ECB(电子密码本模式)是一种简单的加密方式,将数据分成固定长度的块进行加密。以下是ECB模式的加密和解密方法:

import CryptoJS from 'crypto-js';

/**
 * AES加密处理(ECB模式)
 */
export function encryptECB(plaintText) {
    var plaintText = plaintText;
    var options = {
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7
    };
    var key = CryptoJS.enc.Utf8.parse("abcdefgabcdefg12"); //秘钥
    var encryptedData = CryptoJS.AES.encrypt(plaintText, key, options);
    var encryptedBase64Str = encryptedData.toString().replace(/\//g, "_");
    encryptedBase64Str = encryptedBase64Str.replace(/\+/g,"-");
    return encryptedBase64Str;
}
/**
 * AES解密处理(ECB模式)
 */
export function decryptECB(encryptedBase64Str) {
    var vals = encryptedBase64Str.replace(/\-/g, '+').replace(/_/g, '/');
    var options = {
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7
    };
    var key = CryptoJS.enc.Utf8.parse("abcdefgabcdefg12"); //秘钥
    var decryptedData = CryptoJS.AES.decrypt(vals, key, options);
    var decryptedStr = CryptoJS.enc.Utf8.stringify(decryptedData);
    return decryptedStr
}

CBC模式

CBC(密码块链接模式)通过使用前一个块的加密结果来影响当前块的加密过程,从而提高安全性。以下是CBC模式的加密和解密方法:

import CryptoJS from 'crypto-js'

/**
 * AES加密处理(CBC模式)
 */
export function encryptCBC(word, keyStr, ivStr) {
    keyStr = keyStr ? keyStr : "abcdefgabcdefg12";
    ivStr = ivStr ? ivStr : "!@#$%asdfg12345";
    let key = CryptoJS.enc.Utf8.parse(keyStr);
    let iv = CryptoJS.enc.Utf8.parse(ivStr);
    let srcs = CryptoJS.enc.Utf8.parse(word);
    let encrypted = CryptoJS.AES.encrypt(srcs, key, {
        iv,
        mode: CryptoJS.mode.CBC,
        padding: CryptoJS.pad.ZeroPadding
    })
    return encrypted.toString()
}
/**
 * AES解密处理(CBC模式)
 */
 export function decryptCBC(word, keyStr, ivStr) {
    word = (word + '').replace(/\n*$/g, '').replace(/\n/g, ''); //增加这一行,将换行符替换为空
    keyStr = keyStr ? keyStr : "abcdefgabcdefg12";
    ivStr = ivStr ? ivStr : "!@#$%asdfg12345";
    var key = CryptoJS.enc.Utf8.parse(keyStr);
    let iv = CryptoJS.enc.Utf8.parse(ivStr);
    var decrypt = CryptoJS.AES.decrypt(word, key, {
        iv,
        mode: CryptoJS.mode.CBC,
        padding: CryptoJS.pad.ZeroPadding
    })
    return decrypt.toString(CryptoJS.enc.Utf8)
}

使用方法

在Vue组件中,您可以导入并使用这些方法来加密和解密数据。例如:

import { encryptECB, decryptECB, encryptCBC, decryptCBC } from "@/util/aes";

// 使用CBC模式加密WebSocket URL
const encrypted = encryptCBC("ws://192.168.30.110:15674/ws");
console.log(encrypted); // 输出加密后的数据:O6hoY/k1QZ+0eYMSciwxTZUceXKdQ9EWXkdSIECwf9c=

const decrypted = decryptCBC(encrypted);
console.log(decrypted); // 输出解密后的数据:ws://192.168.30.110:15674/ws

安全性考虑

  • 密钥和初始化向量(IV)应该安全地存储和管理,避免硬编码在代码中。
  • CBC模式相较于ECB模式提供了更高的安全性,因此在可能的情况下推荐使用CBC模式。
  • 选择合适的分组大小和填充方式,以平衡性能和安全性。

通过本文的介绍,您应该能够理解并实现Vue项目中的AES加密解密功能,希望这些信息对您的项目有所帮助。

  • 18
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 3实现AES数据加密,你可以按照以下步骤进行操作: 1. 首先,确保你已经安装了crypto库。 2. 在Vue组件,引入crypto库并导入Crypto对象。 3. 创建一个方法,比如encryptAES,用于进行AES加密。 4. 在encryptAES方法,使用Crypto对象调用encrypt方法对数据进行加密。加密的方式可以选择AES-CBC模式。 5. 在调用encrypt方法时,传入需要加密的数据和密码作为参数。密码需要先进行AES加密,可以使用Crypto对象的encrypt方法。 6. 在Vue模板,调用encryptAES方法并传入需要加密的数据。 通过以上步骤,你可以在Vue 3实现AES数据加密。这样可以增加数据的安全性,并确保前后端使用相同的加密格式进行对比,以实现安全登陆。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue 使用AES 加密](https://blog.csdn.net/qq_42108937/article/details/125291710)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [如何基于python3和Vue实现AES数据加密](https://download.csdn.net/download/weixin_38647517/12853811)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值