Vue項(xiàng)目如何實(shí)現(xiàn)rsa加密
如何實(shí)現(xiàn)rsa加密
引言
客戶端初始化訪問登錄服務(wù)時(shí),需要以賬號(hào)和密碼作為參數(shù)請(qǐng)求后臺(tái)接口,此時(shí)后臺(tái)響應(yīng)會(huì)展示出詳細(xì)的賬號(hào)和密碼,為了提高安全性,一般需要對(duì)響應(yīng)中的密碼進(jìn)行加密處理。在這里主要是總結(jié)了rsa加密方法。
安裝jsencrypt
npm i jsencrypt
引入jsencrypt
在 main.js 文件中引入 jsencrypt
import JSEncrypt from "jsencrypt"; //引入模塊 Vue.prototype.$jsEncrypt = JSEncrypt; //配置全局變量
獲取公鑰(調(diào)接口)
export function getPubKey(data) { ? return http({ ? ? url: "/index/pub-key", //每個(gè)項(xiàng)目的接口url不一樣 根據(jù)實(shí)際情況修改 ? ? method: "GET", // 同理 ? ? data ? }); }
引入getPubKey
在需要加密的組件中引入getPubKey接口,然后進(jìn)行賬號(hào)或者密碼加密。下面是以登錄頁面賬號(hào)、密碼加密為例。
1、在login.vue文件中引入getPubKey
import { getPubKey } from "@/api"; //每個(gè)項(xiàng)目路徑都會(huì)有區(qū)別
2、登陸時(shí)加密
?getPubKey().then(({ result, data: keyData }) => { // getPubKey---獲取公鑰接口 ? ? ? ? if (result) { ? ? ? ? ? const jse = new this.$jsEncrypt(); // 實(shí)例化一個(gè) jsEncrypt 對(duì)象 ? ? ? ? ? jse.setPublicKey(keyData); //配置公鑰 ? ? ? ? ? let userAccount = jse.encrypt(this.loginForm.user); //加密賬號(hào) ? ? ? ? ? let passWord = jse.encrypt(this.loginForm.password); //加密密碼 ? ? ? ? ? login({ ? ? ? ? ? ? userAccount: userAccount, ? ? ? ? ? ? passWord: passWord, ? ? ? ? ? }).then(({ result, message }) => { ? ? ? ? ? ? if (result) { ? ? ? ? ? ? ? console.log("登錄成功"); ? ? ? ? ? ? ? // 登錄成功后的操作 ? ? ? ? ? ? } else { ? ? ? ? ? ? ? // 登錄失敗操作 ? ? ? ? ? ? ? this.loginTextError = message; ? ? ? ? ? ? } ? ? ? ? ? }); ? ? ? ? } ? ? ? });
使用rsa加密,解密,加簽,解簽
vue中使用RSA加密,解密,加簽,驗(yàn)簽 安裝引js加密解密加簽,驗(yàn)簽測(cè)試
安裝
- 一個(gè)是進(jìn)行加密,解密的: npm install jsencrypt --save
- 如果加密過長使用 npm i encryptlong --save
- 一個(gè)是進(jìn)行簽名驗(yàn)證的: npm install jsrsasign --save
引js
/* 產(chǎn)引入jsencrypt實(shí)現(xiàn)數(shù)據(jù)RSA加密 / import JSEncrypt from ‘jsencrypt' // 處理長文本數(shù)據(jù)時(shí)報(bào)錯(cuò) jsencrypt.js Message too long for RSA / 產(chǎn)引入encryptlong實(shí)現(xiàn)數(shù)據(jù)RSA加密 */ import Encrypt from ‘encryptlong' // encryptlong是基于jsencrypt擴(kuò)展的長文本分段加解密功能。
加密解密
/* JSEncrypt加密 / rsaPublicData(data) { var jsencrypt = new JSEncrypt() jsencrypt.setPublicKey(publicKey) // 如果是對(duì)象/數(shù)組的話,需要先JSON.stringify轉(zhuǎn)換成字符串 var result = jsencrypt.encrypt(data) return result }, / JSEncrypt解密 */ rsaPrivateData(data) { var jsencrypt = new JSEncrypt() jsencrypt.setPrivateKey(privateKey) // 如果是對(duì)象/數(shù)組的話,需要先JSON.stringify轉(zhuǎn)換成字符串 var result = jsencrypt.encrypt(data) return result }, /* Encrypt 加密*/ function getEncrypt(data) { let encrypt = new Encrypt(); encrypt.setPublicKey(“你的公鑰”); let info = encrypt.encryptLong(JSON.stringify(data)) return info } /* Encrypt 解密*/ function getDecrypt(data) { let decrypt = new Encrypt(); decrypt.setPrivateKey(“你的私鑰”); let info = decrypt.decryptLong(data) return info }
加簽,驗(yàn)簽
在main.js中引入
import jsrsasign from 'jsrsasign'
掛載在main.js中
Vue.prototype.$getSign = function (signData) { var priK = "-----BEGIN PRIVATE KEY-----你的私鑰-----END PRIVATE KEY-----"; //創(chuàng)建rsa實(shí)例 var rsa = new jsrsasign.RSAKey(); //因?yàn)楹蠖颂峁┑氖莗ck#8的密鑰對(duì),所以這里使用 KEYUTIL.getKey來解析密鑰 rsa = jsrsasign.KEYUTIL.getKey(priK); // rsa.readPrivateKeyFromPEMString(priK); let sig = new jsrsasign.KJUR.crypto.Signature({"alg": "SHA256withRSA"}); // 初始化 sig.init(rsa) // 傳入待加密字符串 sig.updateString(signData) // 生成密文 let sign = jsrsasign.hextob64(sig.sign()); // 對(duì)加密后內(nèi)容進(jìn)行URI編碼 // sign = encodeURIComponent(sign); console.log(sign); }
Vue.prototype.$getSignCode = function (strIng) { // 創(chuàng)建RSAKey對(duì)象 var rsa = new jsrsasign.RSAKey(); //因?yàn)楹蠖颂峁┑氖莗ck#8的秘鑰對(duì),所以這里使用 KEYUTIL.getKey來解析秘鑰 var signPrivateKey = `-----BEGIN PRIVATE KEY----- 你的公鑰 -----END PRIVATE KEY-----` // 將密鑰轉(zhuǎn)碼,其實(shí)就是將頭部尾部默認(rèn)字符串去掉 signPrivateKey = jsrsasign.KEYUTIL.getKey(signPrivateKey ); // 創(chuàng)建Signature對(duì)象,設(shè)置簽名編碼算法 // alg:對(duì)應(yīng)的是規(guī)則 需要和后端統(tǒng)一 var sig = new jsrsasign.KJUR.crypto.Signature({ "alg": "SHA256withRSA", "prov": "cryptojs/jsrsa", "prvkeypem": signPrivateKey }); // 初始化 sig.init(signPrivateKey ) // 傳入待加密字符串 sig.updateString(strIng); // 生成密文 var sign = jsrsasign.hextob64(sig.sign()); console.log(sign) // 對(duì)加密后內(nèi)容進(jìn)行URI編碼 // sign = encodeURIComponent(sign); //把參數(shù)與密文拼接好,返回 var params = 'Str=' + strIng + '&sign=' + sign; return sign; }
測(cè)試
//參數(shù) req var req = {}; req["equipmentType"]='00'; req["equipmentIp"] = '192.168.3.23'; //JSON.stringify(req) 轉(zhuǎn)成json字符串 console.log(JSON.stringify(req)) var r = this.$getSignCode(JSON.stringify(req)); var e = this.$attestationCode(JSON.stringify(req), r); console.log(e);
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
在vue中實(shí)現(xiàn)iframe嵌套Html頁面及注意事項(xiàng)說明
這篇文章主要介紹了在vue中實(shí)現(xiàn)iframe嵌套Html頁面及注意事項(xiàng)說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10vue、uniapp中動(dòng)態(tài)添加綁定style、class?9種實(shí)現(xiàn)方法
這篇文章主要介紹了vue、uniapp中動(dòng)態(tài)添加綁定style、class?9種方法實(shí)現(xiàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09Vue中Layout內(nèi)部布局el-row、el-col的實(shí)現(xiàn)
layout是一種非常方便的布局方式,本文主要介紹了Vue中Layout內(nèi)部布局el-row、el-col的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-07-07解決vue無法加載文件C:\Users\Administrator\AppData\Roaming\npm\vue.ps
這篇文章主要介紹了解決vue無法加載文件C:\Users\Administrator\AppData\Roaming\npm\vue.ps1因?yàn)樵诖讼到y(tǒng)上禁止運(yùn)行腳本問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03Vue過濾器,生命周期函數(shù)和vue-resource簡單介紹
這篇文章主要介紹了Vue過濾器,生命周期函數(shù)和vue-resource簡單介紹,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下2021-01-01Vue tagsview實(shí)現(xiàn)多頁簽導(dǎo)航功能流程詳解
基本上后臺(tái)管理系統(tǒng)都需要有多頁簽的功能,但是因?yàn)橐恍┠_手架項(xiàng)目基本都把這個(gè)功能給集成好了,導(dǎo)致在學(xué)習(xí)或者修改的時(shí)候不知道該如何下手。今天這篇文章就來聊一聊,vue-element-admin項(xiàng)目是如何實(shí)現(xiàn)多頁簽功能的2022-09-09vue2.0 和 animate.css的結(jié)合使用
animate.css是一款前端動(dòng)畫庫,相似的有velocity-animate。這篇文章給大家介紹vue2.0 和 animate.css的結(jié)合使用,需要的朋友參考下吧2017-12-12ElementUI的this.$notify.close()調(diào)用不起作用的解決
本文主要介紹了ElementUI的this.$notify.close()調(diào)用不起作用的解決,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08