jsencrypt来对登录密码进行rsa(非对称)加密处理

前端 crypto-js aes(对称) 加解密

什么是RSA加密

RSA加密算法是一种非对称加密算法,RSA加密使用了”一对”密钥.分别是公钥和私钥,这个公钥和私钥其实就是一组数字!其二进制位长度可以是1024位或者2048位.长度越长其加密强度越大,目前为止公之于众的能破解的最大长度为768位密钥,只要高于768位,相对就比较安全.所以目前为止,这种加密算法一直被广泛使用.
RSA加密与解密
使用公钥加密的数据,利用私钥进行解密
使用私钥加密的数据,利用公钥进行解密
https://www.npmjs.com/package/jsencrypt?activeTab=versions

RSA秘钥生成方式

Mac系统

Mac系统内置OpenSSL(开源加密库),所以可以直接在终端上使用命令。
生成私钥,密钥长度为1024bit

  1. # 生成私钥
  2. openssl genrsa -out rsa_1024_priv.pem 1024
  3. # 提取私钥
  4. cat rsa_1024_priv.pem
  5. # 获取公钥
  6. openssl rsa -pubout -in rsa_1024_priv.pem -out rsa_1024_pub.pem
  7. # 查看
  8. cat rsa_1024_pub.pem

Windows系统

Windows系统可以使用git命令行工具
单击鼠标右键——git bash here 调出git bash
查看C:\Users\xiao.ssh 目录下是否存在公私钥,如果存在可以直接使用,如果想要重新生成也可以,可以自定义生成的文件路径,以免覆盖原先的公私钥引发别的场景不能使用的问题。

$ ssh-keygen -t rsa -C "youremail@example.com"

// -f 指定文件名
// 在当前目录生成密钥文件 test, test.pub
ssh-keygen -t rsa -f test -C "test key"
PS C:\Users\xiao> ls test*


    目录: C:\Users\xiao


Mode                 LastWriteTime         Length Name
----                 -------------         ------ ----
-a----         2021/12/3     16:51           2590 test
-a----         2021/12/3     16:51            563 test.pub


PS C:\Users\xiao>

Windows下的问题

Windows下使用 ssh-keygen 生成的公私钥,不能正常对数据进行加解密
可以在linux下生成,然后使用,或者使用在线生成密钥工具生成并使用。

npm install jsencrypt -S
import JSEncrypt from ‘jsencrypt’

rsa加密

var encryptor = new JSEncrypt()  // 创建加密对象实例  
//之前ssl生成的公钥,复制的时候要小心不要有空格   
var pubKey = '-----BEGIN PUBLIC KEY-----xxxxx-----END PUBLIC KEY-----'   encryptor.setPublicKey(pubKey)//设置公钥   
var rsaPassWord = encryptor.encrypt('要加密的内容')  // 对内容进行加密

rsa解密

var decrypt = new JSEncrypt()//创建解密对象实例
//之前ssl生成的秘钥   
var priKey  = '-----BEGIN RSA PRIVATE KEY-----xxxxx=-----END RSA PRIVATE KEY----'   
decrypt.setPrivateKey(priKey)//设置秘钥   
var uncrypted = decrypt.decrypt(encrypted)//解密之前拿公钥加密的内容

对称加解密速度更快,非对称加解密性能上不占优势

前后端各种数据格式加解密
[

](https://www.cnblogs.com/huanzi-qch/p/10913636.html)