欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3 如何使用CryptoJS加密

 更新時(shí)間:2024年10月16日 11:41:05   作者:茶顏悅色  
CryptoJS是一個(gè)強(qiáng)大的JavaScript庫(kù),它提供了多種加密解密功能,尤其是AES加密方法,使用CryptoJS,我們可以有效地保護(hù)數(shù)據(jù)安全,防止信息泄露,通過(guò)簡(jiǎn)單的安裝和函數(shù)編寫(xiě),本文給大家介紹Vue3 如何使用CryptoJS加密,感興趣的朋友一起看看吧

為什么要加密?

現(xiàn)在的互聯(lián)網(wǎng)世界充滿了各種各樣的信息,有些信息非常重要,比如密碼、個(gè)人信息等。如果我們把這些信息直接發(fā)送到服務(wù)器,別人可能會(huì)截取到,然后偷走我們的信息。為了避免這種情況發(fā)生,我們需要把重要的信息變成別人看不懂的東西,這就是加密的作用。

CryptoJS 是什么?

CryptoJS 是一個(gè)非常好用的 JavaScript 庫(kù),它能幫我們加密和解密信息。這個(gè)庫(kù)很小巧,而且功能很強(qiáng)大,支持很多種加密方法。我們這里主要用它的 AES 加密功能。

如何安裝 CryptoJS?

首先,我們需要在項(xiàng)目里安裝 CryptoJS??梢杂孟旅娴拿顏?lái)安裝:

npm install crypto-js

或者

yarn add crypto-js

如何加密和解密?

現(xiàn)在我們已經(jīng)有了 CryptoJS,接下來(lái)就可以寫(xiě)代碼來(lái)加密和解密信息了。

密鑰和偏移量

加密需要一把“鑰匙”,這把鑰匙就是密鑰。另外還有一個(gè)叫“偏移量”的東西,它可以幫助我們更好地加密信息。這兩個(gè)東西一定要保密,不能讓別人知道。

import * as CryptoJS from "crypto-js";
// 密鑰和偏移量
// 這里使用環(huán)境變量來(lái)設(shè)置密鑰和偏移量,確保它們的安全性
const key = CryptoJS.enc.Utf8.parse(process.env.VUE_APP_KEY);
const iv = CryptoJS.enc.Utf8.parse(process.env.VUE_APP_IV);

加密函數(shù)

我們寫(xiě)一個(gè)函數(shù)來(lái)加密信息。這個(gè)函數(shù)接收一段明文(也就是正常能看懂的文字),然后返回加密后的文字。

// AES加密函數(shù)
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 // 使用偏移量
  });
  // 將加密后的數(shù)據(jù)轉(zhuǎn)換成 Base64
  const base64Cipher = encrypted.ciphertext.toString(CryptoJS.enc.Base64);
  // 處理 Android 某些低版本的 BUG
  // 替換某些特殊字符,因?yàn)榧用芎蟮?Base64 字符串在某些設(shè)備上會(huì)有問(wèn)題
  const resultCipher = base64Cipher.replace(/\+/g, "-").replace(/\//g, "_");
  // 返回加密后的經(jīng)過(guò)處理的 Base64
  return resultCipher;
}

解密函數(shù)

我們還需要一個(gè)函數(shù)來(lái)解密信息。這個(gè)函數(shù)接收加密后的文字,然后返回正常的明文。

// AES解密函數(shù)
export function decrypt(encryptData: string): string {
  try {
    // 先將 Base64 還原一下,因?yàn)榧用艿臅r(shí)候做了一些字符的替換
    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 // 使用偏移量
    });
    // 將解密對(duì)象轉(zhuǎn)換成 UTF8 的字符串
    const resultDecipher = CryptoJS.enc.Utf8.stringify(decryptedContent);
    // 返回解密結(jié)果
    return resultDecipher;
  } catch (error) {
    // 如果解密失敗,返回空字符串
    return ""; 
  }
}

如何在 Vue.js 項(xiàng)目中使用

假設(shè)我們有了上面的加密和解密函數(shù),現(xiàn)在要在 Vue.js 項(xiàng)目中使用它們。

創(chuàng)建一個(gè) Vue 組件

我們創(chuàng)建一個(gè)簡(jiǎn)單的 Vue 組件,讓用戶輸入一些信息,然后可以加密和解密。

<template>
  <div>
    <input type="text" v-model="plaintext" placeholder="請(qǐng)輸入明文" />
    <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'; // 導(dǎo)入我們寫(xiě)的加密和解密函數(shù)
// 定義響應(yīng)式狀態(tài)
const plaintext = ref('');
const ciphertext = ref('');
const decryptedText = ref('');
// 加密文本
function encryptText() {
  ciphertext.value = encrypt(plaintext.value);
}
// 解密文本
function decryptText() {
  decryptedText.value = decrypt(ciphertext.value);
}
</script>

到此這篇關(guān)于Vue3 使用CryptoJS加密的文章就介紹到這了,更多相關(guān)Vue3 CryptoJS加密內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論