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