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中填寫如下代碼鄙信,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位。