在Vue项目中使用jsencrypt.js对数据进行加密传输的方法
程序员文章站
2023-02-02 15:34:12
项目需求中需要对用户登录时的密码进行加密,在网上查询些许文章后,最终与后端协商使用jsencrypt.js。
jsencrypt.js的github地址: ...
使用...
项目需求中需要对用户登录时的密码进行加密,在网上查询些许文章后,最终与后端协商使用jsencrypt.js。
jsencrypt.js的github地址: ...
使用yarn安装至vue项目
yarn add jsencrypt --dep
或者使用npm
npm install jsencrypt --dep
引入jsencrypt
import { jsencrypt } from 'jsencrypt'
可封装为全局混合,便于调用
公钥为后端提供,如前端需要解密数据,则需要后端提供私钥。此处只封装了加密。
methods: { // 加密 encrypteddata(publickey, data) { // 新建jsencrypt对象 let encryptor = new jsencrypt(); // 设置公钥 encryptor.setpublickey(publickey); // 加密数据 return encryptor.encrypt(data); } }
调用函数加密,此处的公钥是我从后端那获取的,然后加密密码
encryptedpassword = this.encrypteddata(publickey, password);
即完成加密。
更多使用可查阅官方文档 ...
ps:下面看下jsencrypt 配置对密码进行加密(vue)
安装
npm i node-jsencrypt
在script下导入
// 引入加密模块,对密码进行处理 const jsencrypt = require('jsencrypt');
引用
一般情况下,后台会给一个获取公钥的接口来进行转换
methods: { init() { // 发送请求,获取公钥 getkey().then(res => { this.gongkey = res.data.data; // 获取到公钥 // 传入所请求回来的公钥,对密码进行处理 // 实例化加密对象 var crypt = new jsencrypt.jsencrypt({ default_key_size: 1024 }); crypt.setpublickey(this.gongkey); // 拿到加密明文 let password = crypt.encrypt(obj.value); }); } }
总结
以上所述是小编给大家介绍的在vue项目中使用jsencrypt.js对数据进行加密传输的方法,希望对大家有所帮助