RSA 非对称加密解密简单实现方法

package com.vguang.legalheadlines.law.controller;

import cn.hutool.crypto.asymmetric.KeyType;
import cn.hutool.crypto.asymmetric.RSA;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;

/**
 * @author LiWenBin
 * RSA非堆成加密方法
 */
public class RSAController {
    @Value("${pcPrivateKey:}")
    private String pcPrivateKey;
    @Value("${pcPublicKey:}")
    private String pcPublicKey;
    /**
     * 公钥加密私钥解密
     */
    @GetMapping("/encryption")
    public  String bind() {
        RSA rsa = new RSA(null, pcPublicKey);
        String data="123456";//密码
        String s = rsa.encryptBase64(data, KeyType.PublicKey);
        System.out.println(s);//公钥加密后密码
        RSA rsa2 = new RSA(pcPrivateKey, null);
        String s1 = rsa2.decryptStr(s, KeyType.PrivateKey);
        System.out.println(s1);//私钥解密后密码
        return s1;
    }
    /**
     * 私钥加密公钥解密
     */
    @GetMapping("/encryption2")
    public String bindas() {
        RSA rsa = new RSA(pcPrivateKey,null );
        String data="123456";//密码
        String s = rsa.encryptBase64(data, KeyType.PrivateKey);
        System.out.println(s);//私钥加密后密码
        RSA rsa2 = new RSA(null, pcPublicKey);
        String s1 = rsa2.decryptStr(s, KeyType.PublicKey);
        System.out.println(s1);//公钥解密后密码
        return s1;
    }


}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值