欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-05-15 08:36:48
项目需求中需要对用户登录时的密码进行加密,在网上查询些许文章后,最终与后端协商使用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对数据进行加密传输的方法,希望对大家有所帮助