在Vue项目中使用jsencrypt.js对数据进行加密传输的方法


Posted in Javascript onApril 17, 2019

项目需求中需要对用户登录时的密码进行加密,在网上查询些许文章后,最终与后端协商使用jsencrypt.js。

jsencrypt.js的github地址: https://github.com/travist/js...

使用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);

即完成加密。

更多使用可查阅官方文档 http://travistidwell.com/jsen...

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对数据进行加密传输的方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
JQuery学习笔记 nt-child的使用
Jan 17 Javascript
两个select多选模式的选项相互移动(示例代码)
Jan 11 Javascript
使用AngularJS制作一个简单的RSS阅读器的教程
Jun 18 Javascript
谈谈JSON对象和字符串之间的相互转换JSON.stringify(obj)和JSON.parse(string)
Oct 01 Javascript
jQuery插件cxSelect多级联动下拉菜单实例解析
Jun 24 Javascript
网页挂马方式整理及详细介绍
Nov 03 Javascript
微信公众号开发 自定义菜单跳转页面并获取用户信息实例详解
Dec 08 Javascript
如何制作幻灯片(代码分享)
Jan 06 Javascript
Angular4学习笔记之新建项目的方法
Jul 18 Javascript
本地搭建微信小程序服务器的实现方法
Oct 27 Javascript
vue 系列——vue2-webpack2框架搭建踩坑之路
Dec 22 Javascript
layui实现多图片上传并限制上传的图片数量
Sep 26 Javascript
js的继承方法小结(prototype、call、apply)(推荐)
Apr 17 #Javascript
详解JavaScript的内存空间、赋值和深浅拷贝
Apr 17 #Javascript
Vue源码探究之虚拟节点的实现
Apr 17 #Javascript
ES6知识点整理之数组解构和字符串解构的应用示例
Apr 17 #Javascript
ES6知识点整理之对象解构赋值应用示例
Apr 17 #Javascript
ES6知识点整理之函数对象参数默认值及其解构应用示例
Apr 17 #Javascript
仿vue-cli搭建属于自己的脚手架的方法步骤
Apr 17 #Javascript
You might like
php 抽象类的简单应用
2011/09/06 PHP
PHP 5.5 创建和验证哈希最简单的方法详解
2013/11/07 PHP
php实现的Cookies操作类实例
2014/09/24 PHP
php访问数组最后一个元素的函数end()用法
2015/03/18 PHP
PHP中的Trait 特性及作用
2016/04/03 PHP
php排序算法实例分析
2016/10/17 PHP
php设计模式之组合模式实例详解【星际争霸游戏案例】
2020/03/27 PHP
js 获取中文拼音,Select自动匹配字母获取值的代码
2009/09/23 Javascript
自己实现string的substring方法 人民币小写转大写,数字反转,正则优化
2012/09/02 Javascript
jquery js 获取时间差、时间格式具体代码
2013/06/05 Javascript
对new functionName()定义一个函数的理解
2014/05/22 Javascript
Javascript 多物体运动的实现
2014/12/24 Javascript
JS实现的添加弹出层并完成锁屏操作示例
2017/04/07 Javascript
form表单数据封装成json格式并提交给服务器的实现方法
2017/12/14 Javascript
js实现把时间戳转换为yyyy-MM-dd hh:mm 格式(es6语法)
2017/12/28 Javascript
Nodejs模块载入运行原理
2018/02/23 NodeJs
electron制作仿制qq聊天界面的示例代码
2018/11/26 Javascript
vue router 用户登陆功能的实例代码
2019/04/24 Javascript
[46:53]Secret vs Liquid 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python根据区号生成手机号码的方法
2015/07/08 Python
Python读取指定目录下指定后缀文件并保存为docx
2017/04/23 Python
Python实现树的先序、中序、后序排序算法示例
2017/06/23 Python
Python使用回溯法子集树模板解决爬楼梯问题示例
2017/09/08 Python
浅谈python装饰器探究与参数的领取
2017/12/01 Python
解决python 自动安装缺少模块的问题
2018/10/22 Python
通过python的matplotlib包将Tensorflow数据进行可视化的方法
2019/01/09 Python
python调用外部程序的实操步骤
2019/03/04 Python
详解python中eval函数的作用
2019/10/22 Python
英国计算机商店:Technextday
2019/12/28 全球购物
出纳岗位职责模板
2013/11/27 职场文书
国庆节演讲稿
2014/05/27 职场文书
体育系毕业生自荐信
2014/06/28 职场文书
世界环境日活动总结
2015/02/11 职场文书
公司辞职信模板
2015/05/13 职场文书
观看安全警示教育片心得体会
2016/01/15 职场文书
idea编译器vue缩进报错问题场景分析
2021/07/04 Vue.js