美文网首页算法
前端利用jsencrypt.js进行RSA加密

前端利用jsencrypt.js进行RSA加密

作者: WEB前端含光 | 来源:发表于2020-07-28 15:00 被阅读0次

    写在前面

    对于加密的学习一直很迷茫,但是今天看到博主的这篇文章感觉非常的通俗易懂,为了方便以后查阅,所以就保存下来,在此附上 博主文章的地址

    什么是RSA加密

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

    RSA加密与解密

    • 使用 公钥 加密的数据,利用 私钥 进行解密
    • 使用 私钥 加密的数据,利用 公钥 进行解密

    RSA秘钥生成方式

    Mac系统内置OpenSSL(开源加密库),所以可以直接在终端上使用命令。

    Windows系统可以使用git命令行工具

    • 单击鼠标右键——git bash here 调出git bash
    • 生成私钥,密钥长度为1024bit
    $ openssl genrsa -out private.pem 1024
        Generating RSA private key, 1024 bit long modulus (2 primes)
        ...+++++
        .............................+++++
        e is 65537 (0x010001)
    

    从私钥中提取公钥

    $ openssl rsa -in private.pem -pubout -out public.pem
      writing RSA key
    

    这样就生成了private.pem 和 public.pem两个文件,可以利用终端进行查看

    $ cat private.pem
    -----BEGIN RSA PRIVATE KEY-----
    MIICXQIBAAKBgQDNNorgFngK1zjHOnQlIUh5NjOxZIiEPZ8Knu6B/IyY0LBRToo1
    TZC7/nK6j8on/2sBdv5nFuTwlOpW9UL8C4yZJdjTwYXn5X+wZZsz1RXNI5zjhSXu
    GeYzF7WhxusKo6zrR6b0IMNg2W016PWU3UkjOXxoaIGkMN77oIorPP5bHQIDAQAB
    AoGABOdOvjgLOkcWRjxxVgnLj4nqBk0erfpC+J//lv+P5H7oF6lGyCtIUBWubCLP
    c9E4n1pWjeQQKGeGiflmVlt4So2UPQJD/fvpmT0lswaud+ObbUtFIo4CApHMXdTB
    jIC/nDSdFut2Yd32N8OH/QYnzAS1tarLGjk3x+Dg5nY3VEECQQDvM7GLXT2df85I
    X+FBX9YiwUPXqciUJp3XdBOngsyENOFu0C3/cBTxvaiKkMXVPqMjOdoCAY+hz/k1
    xPUVBpZ5AkEA25/Objru9LI1XSj8M1gJoIUpiR+mJysN7Q7wWbSK6DI+Hz95NQ5r
    kAzG89lwMW3dLycH8VPGsWMuxjA7NG0QxQJBAIxDxdKxJFZdAXuTLaWGKy1KIxwt
    pT6qvlf+6x+JJaBI2gB+9toYwU9YJaLLbhazmjonzFzsyWrbZ4lOK2De8hECQQCl
    uJRgAQBGjCJQRZjodUnuYgzRd5w8efRsKJWcWutmAmN12MNxEYyAieOmJTDPW4NH
    DUClDP4k5B5rVgGWsaWxAkA4m0bHwiPqO4/Yz6eyl2jYvljtmqr7KZFXrlsBUrIm
    XXaTuMdsOmLlp/u078XFw0N+RaUWxbE6ATH7mTGjB2nV
    -----END RSA PRIVATE KEY-----
    $ cat public.pem
    -----BEGIN PUBLIC KEY-----
    MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDNNorgFngK1zjHOnQlIUh5NjOx
    ZIiEPZ8Knu6B/IyY0LBRToo1TZC7/nK6j8on/2sBdv5nFuTwlOpW9UL8C4yZJdjT
    wYXn5X+wZZsz1RXNI5zjhSXuGeYzF7WhxusKo6zrR6b0IMNg2W016PWU3UkjOXxo
    aIGkMN77oIorPP5bHQIDAQAB
    -----END PUBLIC KEY-----
    

    利用 工具网站 在线生成秘钥

    jsencrypt介绍

    jsencrypt就是一个基于rsa加解密的js库

    使用方法

    • 安装
    npm install jsencrypt
    

    引入

    import JSEncrypt from 'jsencrypt'
    

    rsa加密

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

    rsa解密

    var decrypt = new JSEncrypt()//创建解密对象实例
      //之前ssl生成的秘钥
      var priKey  = '-----BEGIN RSA PRIVATE KEY-----MIICXAIBAAKBgQC1QQRl0HlrVv6kGqhgonD6A9SU6ZJpnEN+Q0blT/ue6Ndt97WRfxtSAs0QoquTreaDtfC4RRX4o+CU6BTuHLUm+eSvxZS9TzbwoYZq7ObbQAZAY+SYDgAA5PHf1wNN20dGMFFgVS/y0ZWvv1UNa2laEz0I8Vmr5ZlzIn88GkmSiQIDAQABAoGBAKYDKP4AFlXkVlMEP5hS8FtuSrUhwgKNJ5xsDnFV8sc3yKlmKp1a6DETc7N66t/Wdb3JVPPSAy+7GaYJc7IsBRZgVqhrjiYiTO3ZvJv3nwAT5snCoZrDqlFzNhR8zvUiyAfGD1pExBKLZKNH826dpfoKD2fYlBVOjz6i6dTKBvCJAkEA/GtL6q1JgGhGLOUenFveqOHJKUydBAk/3jLZksQqIaVxoB+jRQNOZjeSO9er0fxgI2kh0NnfXEvH+v326WxjBwJBALfTRar040v71GJq1m8eFxADIiPDNh5JD2yb71FtYzH9J5/d8SUHI/CUFoROOhxr3DpagmrnTn28H0088vubKe8CQDKMOhOwx/tS5lqvN0YQj7I6JNKEaR0ZzRRuEmv1pIpAW1S5gTScyOJnVn1tXxcZ9xagQwlT2ArfkhiNKxjrf5kCQAwBSDN5+r4jnCMxRv/Kv0bUbY5YWVhw/QjixiZTNn81QTk3jWAVr0su4KmTUkg44xEMiCfjI0Ui3Ah3SocUAxECQAmHCjy8WPjhJN8y0MXSX05OyPTtysrdFzm1pwZNm/tWnhW7GvYQpvE/iAcNrNNb5k17fCImJLH5gbdvJJmCWRk=-----END RSA PRIVATE KEY----'
      decrypt.setPrivateKey(priKey)//设置秘钥
      var uncrypted = decrypt.decrypt(encrypted)//解密之前拿公钥加密的内容
    

    目前的应用场景是在用户注册或登录的时候,用公钥对密码进行加密,再去传给后台,后台用私钥对加密的内容进行解密,然后进行密码校验或者保存到数据库。

    我目前是在职前端开发,如果你现在也想学习前端开发技术,在入门学习前端的过程当中有遇见任何关于学习方法,学习路线,学习效率等方面的问题,你都可以申请加我的Q群[链接](点击链接加入群聊【WEB前端技术学习交流群】:1146649671里面看一下,希望能够对你们有所帮助。有我做前端技术这段时间整理的一些前端学习手册,前端面试题,前端开发工具,PDF文档书籍教程,需要的话可以私聊我获取。

    相关文章

      网友评论

        本文标题:前端利用jsencrypt.js进行RSA加密

        本文链接:https://www.haomeiwen.com/subject/cimfrktx.html