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
# 生成私钥openssl genrsa -out rsa_1024_priv.pem 1024# 提取私钥cat rsa_1024_priv.pem# 获取公钥openssl rsa -pubout -in rsa_1024_priv.pem -out rsa_1024_pub.pem# 查看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)//解密之前拿公钥加密的内容
对称加解密速度更快,非对称加解密性能上不占优势
