当前位置: 首页 > article >正文

Vue3 使用CryptoJS加密

为什么要加密?

现在的互联网世界充满了各种各样的信息,有些信息非常重要,比如密码、个人信息等。如果我们把这些信息直接发送到服务器,别人可能会截取到,然后偷走我们的信息。为了避免这种情况发生,我们需要把重要的信息变成别人看不懂的东西,这就是加密的作用。

CryptoJS 是什么?

CryptoJS 是一个非常好用的 JavaScript 库,它能帮我们加密和解密信息。这个库很小巧,而且功能很强大,支持很多种加密方法。我们这里主要用它的 AES 加密功能。

如何安装 CryptoJS?

首先,我们需要在项目里安装 CryptoJS。可以用下面的命令来安装:

npm install crypto-js

或者

yarn add crypto-js

如何加密和解密?

现在我们已经有了 CryptoJS,接下来就可以写代码来加密和解密信息了。

密钥和偏移量

加密需要一把“钥匙”,这把钥匙就是密钥。另外还有一个叫“偏移量”的东西,它可以帮助我们更好地加密信息。这两个东西一定要保密,不能让别人知道。

import * as CryptoJS from "crypto-js";

// 密钥和偏移量
// 这里使用环境变量来设置密钥和偏移量,确保它们的安全性
const key = CryptoJS.enc.Utf8.parse(process.env.VUE_APP_KEY);
const iv = CryptoJS.enc.Utf8.parse(process.env.VUE_APP_IV);
加密函数

我们写一个函数来加密信息。这个函数接收一段明文(也就是正常能看懂的文字),然后返回加密后的文字。

// AES加密函数
export function encrypt(text: string): string {
  // 使用 CryptoJS 的 AES 方法加密文本
  const encrypted = CryptoJS.AES.encrypt(text, key, {
    mode: CryptoJS.mode.ECB, // 使用 ECB 模式
    padding: CryptoJS.pad.Pkcs7, // 使用 PKCS7 填充
    iv: iv // 使用偏移量
  });

  // 将加密后的数据转换成 Base64
  const base64Cipher = encrypted.ciphertext.toString(CryptoJS.enc.Base64);

  // 处理 Android 某些低版本的 BUG
  // 替换某些特殊字符,因为加密后的 Base64 字符串在某些设备上会有问题
  const resultCipher = base64Cipher.replace(/\+/g, "-").replace(/\//g, "_");

  // 返回加密后的经过处理的 Base64
  return resultCipher;
}
解密函数

我们还需要一个函数来解密信息。这个函数接收加密后的文字,然后返回正常的明文。

// AES解密函数
export function decrypt(encryptData: string): string {
  try {
    // 先将 Base64 还原一下,因为加密的时候做了一些字符的替换
    const restoreBase64 = encryptData.replace(/\-/g, "+").replace(/_/g, "/");

    // 解密
    const decryptedContent = CryptoJS.AES.decrypt(restoreBase64, key, {
      mode: CryptoJS.mode.ECB, // 使用 ECB 模式
      padding: CryptoJS.pad.Pkcs7, // 使用 PKCS7 填充
      iv: iv // 使用偏移量
    });

    // 将解密对象转换成 UTF8 的字符串
    const resultDecipher = CryptoJS.enc.Utf8.stringify(decryptedContent);

    // 返回解密结果
    return resultDecipher;
  } catch (error) {
    // 如果解密失败,返回空字符串
    return ""; 
  }
}

如何在 Vue.js 项目中使用

假设我们有了上面的加密和解密函数,现在要在 Vue.js 项目中使用它们。

创建一个 Vue 组件

我们创建一个简单的 Vue 组件,让用户输入一些信息,然后可以加密和解密。

<template>
  <div>
    <input type="text" v-model="plaintext" placeholder="请输入明文" />
    <button @click="encryptText">加密</button>
    <button @click="decryptText">解密</button>
    <p>加密后的文本: {{ ciphertext }}</p>
    <p>解密后的文本: {{ decryptedText }}</p>
  </div>
</template>

<script setup>
import { ref } from 'vue';
import { encrypt, decrypt } from './crypto'; // 导入我们写的加密和解密函数

// 定义响应式状态
const plaintext = ref('');
const ciphertext = ref('');
const decryptedText = ref('');

// 加密文本
function encryptText() {
  ciphertext.value = encrypt(plaintext.value);
}

// 解密文本
function decryptText() {
  decryptedText.value = decrypt(ciphertext.value);
}
</script>

http://www.kler.cn/a/353545.html

相关文章:

  • 9.4 visualStudio 2022 配置 cuda 和 torch (c++)
  • 何为“正则表达式”!
  • Lua语言中常用的字符串操作函数
  • linux 设置mysql 外网访问
  • 麦田物语学习笔记:背包物品选择高亮显示和动画
  • List详解 - 双向链表的操作
  • 介绍 TensorFlow 的基本概念和使用场景(AI)
  • 关于拖拽时需要注意的细节
  • 多层感知机 MLP
  • 【优选算法篇】编织算法的流动诗篇:滑动窗口的轻盈之美
  • Golang | Leetcode Golang题解之第477题汉明距离总和
  • mqtt客户端订阅一直重复连接?
  • 详解SSH和bash
  • 【Linux】嵌入式Linux系统的组成、u-boot编译
  • 灵当CRM data/pdf.php 任意文件读取漏洞复现
  • 计算机网络(五)—— 运输层
  • Springboot +Mybatis项目用log4j2打印SQL语句
  • 推动AI技术研发与应用,景联文科技提供专业高效图像采集服务
  • Spring Cloud 组件的使用
  • 新手爬虫DAY1
  • exchange邮件系统ADFS双因素认证技术方案
  • [移植] tgi 编译
  • element-ui的树形结构样式调整,添加线条和边框样式
  • Git中从dev分支恢复master分支
  • 爬虫逆向学习(十二):一个案例入门补环境
  • perl文件测试操作符及其意义