前端RSA加密解密-JsEncrypt

本文介绍了一种非对称加密算法RSA的实现方法,通过使用公钥和私钥对数据进行加密与解密。文中提供了具体的加密解密过程及代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

RSA加密算法是一种非对称加密算法,RSA加密使用了一对密钥(公钥和私钥)

在线生成密钥生成工具

使用的加密库为

npm i jsencrypt

RSA加密与解密

  • 使用公钥加密的数据,利用私钥进行解密
  • 使用私钥加密的数据,利用公钥进行解密
  • /**
     * 加密工具类
     * Created by wangxiaoying 2019/04/17
     * **/
    import JsEncrypt from 'jsencrypt'
    import store from '../store'
    
    /**
     * 加密
     * @param value 待加密数据
     * @returns 加密结果
     */
    export function RSAencrypt(value) {
      var encrypt = new JsEncrypt()
      // 如果公钥没有了,重新申请公钥
      if (store.getters.publicKey && store.getters.publicKey === '') {
        store.dispatch('GetConfig').then(() => {
          encrypt.setPublicKey(store.getters.publicKey)// 从store中读取公钥
          var enRes = encrypt.encrypt(value)
          console.log('加密结果为:' + enRes)
          return enRes
        }).catch((e) => {
          this.loading = false
        })
      } else {
        encrypt.setPublicKey(store.getters.publicKey)// 从store中读取公钥
        var enRes = encrypt.encrypt(value)
        console.log('加密结果为:' + enRes)
        return enRes
      }
    }
    
    /**
     * 解密
     * @param value 待解密数据
     * @returns 加密结果
     */
     export function RSAdecrypt(value){
      var encrypt = new JsEncrypt()
      if (store.getters.privateKey && store.getters.privateKey === '') {
        store.dispatch('GetConfig').then(() => {
          encrypt.setPrivateKey(store.getters.privateKey)// 从store中读取私钥
          var enRes = encrypt.decrypt(value)
          console.log('解密结果为:' + enRes)
          return enRes
        }).catch((e) => {
          this.loading = false
        })
      } else {
        encrypt.setPrivateKey(store.getters.privateKey)// 从store中读取私钥
        var enRes = encrypt.decrypt(value)
        console.log('解密结果为:' + enRes)
        return enRes
      }
    }
    

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值