AES Base64 sha1加密

vue base64加密解密

安裝

npm install --save js-base64

引入

import { Base64 } from 'js-base64'
或者
let Base64 = require('js-base64').Base64;

使用:

加密:
Base64.encode('小飼弾'); // 5bCP6aO85by+
Base64.encodeURI('小飼弾');
解密:
Base64.decode('ZGFua29nYWk='); // dankogai
Base64.decode('5bCP6aO85by+');

vue md5加密解密

安裝

cnpm install --save js-md5

引入

import md5 from 'js-md5'

使用:

加密:
方式一:
md5('') // d41d8cd98f00b204e9800998ecf8427e
方式二:
在main.js文件中將md5轉(zhuǎn)換成vue原型:

import md5 from 'js-md5'

Vue.prototype.$md5 = md5

在需要用到的文件中使用:
this.$md5('hhhahaah')//612341288a285f5b188163482320e88f

tips:

md5算法是不可逆的,所以經(jīng)過(guò)md5加密過(guò)的字符串是無(wú)法還原(解密)的。一般用作登陸驗(yàn)證的時(shí)候,也是要先經(jīng)過(guò)md5加密然后去數(shù)據(jù)庫(kù)驗(yàn)證密碼是否正確。

vue sha1加密(不可逆)

安裝

cnpm install js-sha1

引入

import sha1 from 'js-sha1' //mian.js

使用:

加密:
sha1(任意字符串)

vue AES加密解密

安裝

cnpm install crypto-js --save-dev

引入

import CryptoJS from 'crypto-js'

使用:

在src目錄下新建個(gè)放公用js文件夾(common),再建一個(gè)AES.js文件
在AES.js中填寫(xiě)如下代碼,key密鑰長(zhǎng)度則可以是128,192或256位(默認(rèn)情況下是128位),正常情況下固定16位數(shù)即可

import CryptoJS from 'crypto-js';
 
export default {
    //隨機(jī)生成指定數(shù)量的16進(jìn)制key
    generatekey(num) {
        let library = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
        let key = "";
        for (var i = 0; i < num; i++) {
            let randomPoz = Math.floor(Math.random() * library.length);
            key += library.substring(randomPoz, randomPoz + 1);
        }
        return key;
    },
    
    //加密
    encrypt(word, keyStr) {
        keyStr = keyStr ? keyStr : 'abcdsxyzhkj12345'; //判斷是否存在ksy,不存在就用定義好的key
        var key = CryptoJS.enc.Utf8.parse(keyStr);
        var srcs = CryptoJS.enc.Utf8.parse(word);
        var encrypted = CryptoJS.AES.encrypt(srcs, key, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 });
        return encrypted.toString();
    },
    //解密
    decrypt(word, keyStr) {
        keyStr = keyStr ? keyStr : 'abcdsxyzhkj12345';
        var key = CryptoJS.enc.Utf8.parse(keyStr);
        var decrypt = CryptoJS.AES.decrypt(word, key, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 });
        return CryptoJS.enc.Utf8.stringify(decrypt).toString();
    }
 
}

在需要的地方引入:

import AES from "@/common/AES.js";

調(diào)用


// var keys = AES.generatekey(16);
 
//如果是對(duì)象/數(shù)組的話,需要先JSON.stringify轉(zhuǎn)換成字符串
// 不傳key值,就默認(rèn)使用上述定義好的key值
 
var encrypts = AES.encrypt(JSON.stringify(cars));
var dess = JSON.parse(AES.decrypt(encrypts));
 
// var encrypts = AES.encrypt('1234asdasd');
// var dess = AES.decrypt(encrypts);
 
console.log(encrypts)
console.log(encrypts.length)
console.log(dess)

tips:

當(dāng)解密的時(shí)候是為空的時(shí)候(也沒(méi)有報(bào)錯(cuò)),那么就一定是你的key長(zhǎng)度不符合規(guī)范, 可以調(diào)整為key長(zhǎng)度為16位。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容