前端实现rsa加密功能

本文将从web和小程序两个端来实现rsa的加密功能。
一般项目的登录密码、身份证号以及一些用户敏感信息等在传输的时候需要使用加密传输,一般来说,前端只会得到后端给的公钥,而rsa加密,可以用公钥加密,也可以用私钥加密,即可以用一个公钥进行加密,也可以去解密后端经过私钥加密的数据,在我的项目中,我只需要把用户输入的信息进行加密传输给后端,所以只需要使用到公钥(这个公钥后端会提供)

1.web端使用rsa加密

首先安装项目所需要的包

  1. 安装jsencrypt
npm install jsencrypt --save-dev
  1. 安装encryptlong
npm install encryptlong --save-dev
  1. 创建rsa.js文件
    在项目的根目录的src文件下创建utils文件夹,创建rsa.js文件

在这里插入图片描述
4 引入并封装加密方法

/* 引入JSEncrypt实现数据RSA加密 */
import JSEncrypt from 'jsencrypt' // 处理长文本数据时报错 JSEncrypt.js Message too long for RSA
/* 引入encryptlong实现数据RSA加密 */
import Encrypt from 'encryptlong' // encryptlong是基于jsencrypt扩展的长文本分段加解密功能。

// RSA 公钥
const publicKey = `后端给的公钥`

export default {
    /**
     * 使用JSEncrypt进行短文本加密
     * @param {string} data - 要加密的数据
     * @param {string} [key=publicKey] - 可选的公钥,默认使用主公钥
     * @returns {string} 加密后的数据
     */
    rsaEncrypt(data, key = publicKey) {
        const jsencrypt = new JSEncrypt();
        jsencrypt.setPublicKey(key);
        // 如果是对象/数组的话,需要先JSON.stringify转换成字符串
        return jsencrypt.encrypt(data);
    },

    /**
     * 使用encryptlong进行长文本加密
     * @param {string} data - 要加密的数据
     * @param {string} [key=publicKey] - 可选的公钥,默认使用主公钥
     * @returns {string} 加密后的数据
     */
    encrypt(data, key = publicKey) {
        const encryptor = new Encrypt();
        encryptor.setPublicKey(key);
        // 如果是对象/数组的话,需要先JSON.stringify转换成字符串
        return encryptor.encryptLong(data);
    }
}

  1. 项目中使用
import Rsa from '@/utils/rsa'
const loginParams: LoginParams = {
      phone: loginForm.value.phone,
      password: Rsa.encrypt(loginForm.value.password)
    }
  1. 添加类型声明
    如果是ts项目,还需要添加rsa文件的类型声明
declare module '@/utils/rsa' {
    interface RsaUtils {
      /**
       * 使用JSEncrypt进行短文本加密
       * @param data - 要加密的数据
       * @param key - 可选的公钥,默认使用主公钥
       */
      rsaEncrypt(data: string, key?: string): string;
  
      /**
       * 使用encryptlong进行长文本加密
       * @param data - 要加密的数据
       * @param key - 可选的公钥,默认使用主公钥
       */
      encrypt(data: string, key?: string): string;
    }
  
    const rsa: RsaUtils;
    export default rsa;
  } 

2.小程序端使用rsa加密

本来也使用和web端同样的方式去引入jsencrypt和encryptlong ,但是一直在报错不能使用。 踩了很多坑发现这两个包的源码的判断的某些字段小程序里并不支持, 所以我们需要直接去修改node_modules里的jsencrypt源码,去做小程序的兼容,也就意味着我们不能使用npm下载的方式去引入(因为不要用npm下载方式,这样引入的还是官方的依赖库,修改是无效的,是在官方的js文件修改后丢入utils文件夹下,再引入),接下来总结几个需要做兼容的地方

  1. 小程序使用jsencrypt加密,报Uncaught TypeError: Cannot read property ‘appName‘ of undefined问题
    解决措施:navigator主要是对浏览器的判断,同时小程序中没有appName,直接删除或者保留最后一个else即可。这个解决后还会有其他的问题按照报错做兼容处理即可
    找到代码中的
    if (j_lm && (navigator.appName == “Microsoft Internet Explorer”)) {
    BigInteger.prototype.am = am2;
    dbits = 30;
    } else if (j_lm && (navigator.appName != “Netscape”)) {
    BigInteger.prototype.am = am1;
    dbits = 26;
    } else { // Mozilla/Netscape seems to prefer am3
    BigInteger.prototype.am = am3;
    dbits = 28;
    }
    直接删掉改为
    BigInteger.prototype.am = am3;
    dbits = 28;

  2. 解决uniapp开发微信小程序AES加密报错:TypeError: Cannot read property ‘crypto‘ of undefined
    if (window.crypto && window.crypto.getRandomValues) { // 生成长度为256,元素值为0的数组
    var z = new Uint32Array(256); // 生成长度为256,元素随机值的数组
    window.crypto.getRandomValues(z);
    }
    替换为
    var getRandomValues = function (array) {
    for (var i = 0, l = array.length; i < l; i++) { array[i] = Math.floor(Math.random() * 256);
    } return array;
    }
    var z = new Uint32Array(256);getRandomValues(z);
    参考文档:参考文档1
    参考文档2
    小程序兼容参考源码:https://github.com/zhangs3721/wx_jsencrypt?tab=readme-ov-file
    https://github.com/UFO0001/WX_RSA?tab=readme-ov-file
    如果想直接下载也可以移步:https://download.csdn.net/download/qq_46435701/90436186
    下载后(引入jsencrypt.min即可,节省项目体积)丢入utils里面,再在rsa文件中引入即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/978192.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

VidSketch:具有扩散控制的手绘草图驱动视频生成

浙大提出的VidSketch是第一个能够仅通过任意数量的手绘草图和简单的文本提示来生成高质量视频动画的应用程序。该方法训练是在单个 RTX4090 GPU 上进行的&#xff0c;针对每个动作类别使用一个小型、高质量的数据集。VidSketch方法使所有用户都能使用简洁的文本提示和直观的手绘…

STM32——HAL库开发笔记23(定时器4—输入捕获)(参考来源:b站铁头山羊)

定时器有四个通道&#xff0c;这些通道既可以用来作为输入&#xff0c;又可以作为输出。做输入的时候&#xff0c;可以使用定时器对外部输入的信号的时间参数进行测量&#xff1b;做输出的时候&#xff0c;可以使用定时器向外输出精确定时的方波信号。 一、输入捕获 的基本原理…

Jquery详解

一.Jquery介绍 1.jQuery 是一个快速、简洁的 JavaScript 库&#xff0c;它极大地简化了 HTML 文档遍历、事件处理、动画效果和 AJAX 交互等操作&#xff0c;使开发者能够更轻松地创建动态和交互性强的网页。对原生js的封装,提供了很多时间,调用Api即可,并且对浏览器做了兼容性…

【EB-06】SystemCreator dbc转arxml

SystemCreator dbc转arxml 1. SystemCreator 意义2. SystemCreator使用方法2.1 实现步骤2.2 参考官方文档方法1. SystemCreator 意义 EB Tresos 对dbc直接导入的支持不是很完善,dbc也不是AUTOSAR标准的数据库文件,EB建议所有通信矩阵通过ARXML交互比较合理(AUTOSAR定义的)…

LeetCode225.用队列实现栈

LeetCode225.用队列实现栈 文章目录 LeetCode225.用队列实现栈题目描述实现1:实现2: 题目描述 请你仅使用两个队列实现一个后入先出&#xff08;LIFO&#xff09;的栈&#xff0c;并支持普通栈的全部四种操作&#xff08;push、top、pop 和 empty&#xff09;。 实现 MyStack…

【Linux】vim 设置

【Linux】vim 设置 零、起因 刚学Linux&#xff0c;有时候会重装Linux系统&#xff0c;然后默认的vi不太好用&#xff0c;需要进行一些设置&#xff0c;本文简述如何配置一个好用的vim。 壹、软件安装 sudo apt-get install vim贰、配置路径 对所有用户生效&#xff1a; …

【FL0091】基于SSM和微信小程序的社区二手物品交易小程序

&#x1f9d1;‍&#x1f4bb;博主介绍&#x1f9d1;‍&#x1f4bb; 全网粉丝10W,CSDN全栈领域优质创作者&#xff0c;博客之星、掘金/知乎/b站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战&#xff0c;以及程序定制化开发…

Javaweb后端数据库多表关系一对多,外键,一对一

多表关系 一对多 多的表里&#xff0c;要有一表里的主键 外键 多的表上&#xff0c;添加外键 一对一 多对多 案例

seacmsv9注入管理员账号密码+orderby+limit

seacmsv9注入管理员账号密码 seacms介绍 海洋影视管理系统&#xff08;seacms&#xff0c;海洋cms&#xff09;是一套专为不同需求的站长而设计的视频点播系统&#xff0c;采用的是 php5.Xmysql 的架构&#xff0c;使用 fofa 搜索可以看到存在 400的记录&#xff1a; 因为sea…

开源基准测试模拟器:BlueROV2 水下机器人的控制(更改Z方向控制器)

开源基准测试模拟器:BlueROV2 水下机器人的控制(更改Z方向控制器) 将原有项目的z方向控制器由自适应滑膜控制器(ASMC)更改为自抗扰控制器(ADRC) 原Z控制器 更改为ADRC后图像 原自适应滑膜控制器代码 function u =

【苍穹外卖】问题笔记

【DAY1 】 1.VCS找不到 好吧&#xff0c;发现没安git 接着发现安全模式有问题&#xff0c;点开代码信任此项目 2.导入初始文件&#xff0c;全员爆红 好像没maven&#xff0c;配一个 并在设置里设置好maven 3.启用注解&#xff0c;见新手苍穹 pom.xml改lombok版本为1.1…

项目实践 之 pdf简历的解析和填充(若依+vue3)

文章目录 环境背景最终效果前端讲解左侧模块解析右侧上传模块解析前端步骤 后端讲解代码前端 环境背景 若依前后端分离框架 vue最后边附有代码哦 最终效果 前端讲解 左侧模块解析 1、左侧表单使用el-form 注意&#xff1a; 1、prop出现的字段&#xff0c;需要保证是该类所…

Web自动化之Selenium控制已经打开的浏览器(Chrome,Edge)

在使用selenium进行web自动化或爬虫的时候,经常会面临登录的情况,对于这种情况,我们可以利用Selenium控制已经打开的浏览器&#xff0c;从而避免每次都需要重新打开浏览器并进行登录的繁琐步骤。 目录 说明 启动浏览器 注意 --user-data-dir说明 代码设定 代码 改进代…

千峰React:案例一

做这个案例捏 因为需要用到样式&#xff0c;所以创建一个样式文件&#xff1a; //29_实战.module.css .active{text-decoration:line-through } 然后创建jsx文件&#xff0c;修改main文件&#xff1a;导入Todos&#xff0c;写入Todos组件 import { StrictMode } from react …

自动驾驶FSD技术的核心算法与软件实现

引言&#xff1a;FSD技术的定义与发展背景 在当今快速发展的科技领域中&#xff0c;自动驾驶技术已经成为全球关注的焦点之一。其中&#xff0c;“FSD”&#xff08;Full Self-Driving&#xff0c;全自动驾驶&#xff09;代表了这一领域的最高目标——让车辆在无需人类干预的情…

Go红队开发—并发编程

文章目录 并发编程go协程chan通道无缓冲通道有缓冲通道创建⽆缓冲和缓冲通道 等协程sync.WaitGroup同步Runtime包Gosched()Goexit() 区别 同步变量sync.Mutex互斥锁atomic原子变量 SelectTicker定时器控制并发数量核心机制 并发编程阶段练习重要的细节端口扫描股票监控 并发编程…

【嵌入式原理设计】实验六:倒车控制设计

目录 一、实验目的 二、实验环境 三、实验内容 四、实验记录及处理 五、实验小结 六、成果文件提取链接 一、实验目的 熟悉和掌握各模块联合控制的工作方式 二、实验环境 Win10ESP32实验开发板 三、实验内容 1、用串口和OLED显示当前小车与障碍物的距离值&#xff1b…

探索浮点数在内存中的存储(附带快速计算补码转十进制)

目录 一、浮点数在内存中的存储 1、常见的浮点数&#xff1a; 2、浮点数存储规则&#xff1a; 3、内存中无法精确存储&#xff1a; 4、移码与指数位E&#xff1a; 5、指数E的三种情况&#xff1a; 二、快速计算补码转十进制 1、第一种方法讨论&#xff1a; 2、第二种方…

实体机器人识别虚拟环境中障碍物

之前的内容已经实现了虚拟机器人识别实体机器人的功能&#xff0c;接下来就是实体机器人如何识别虚拟环境中的障碍物&#xff08;包括虚拟环境中的障碍物和其他虚拟机器人&#xff09;。 我做的是基于雷达的&#xff0c;所以主要要处理的是雷达的scan话题 我的虚拟机器人命名…

湖北中医药大学谱度众合(武汉)生命科技有限公司研究生工作站揭牌

2025年2月11日&#xff0c;湖北中医药大学&谱度众合&#xff08;武汉&#xff09;生命科技有限公司研究生工作站揭牌仪式在武汉生物技术研究院一楼101会议室举行&#xff0c;湖北中医药大学研究生院院长刘娅教授、基础医学院院长孔明望教授、基础医学院赵敏教授、基础医学院…