RSA鉴权算法

RSA鉴权算法

代码

package com;

import org.apache.commons.codec.binary.Base64;

import java.io.IOException;
import java.security.GeneralSecurityException;
import java.security.KeyFactory;
import java.security.PrivateKey;
import java.security.Signature;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;

/**
 * 类描述信息
 *
 * @author l00379908
 * @version [版本号, 2019/10/14]
 * @see [相关类/方法]
 * @since [产品/模块版本]
 */
public class SignVerifierTest {

    private static String SIGN_ALGORITHMS = "SHA256WithRSA";

    public static void main(String[] args) {
        String content = "name=liujie&time=20191014";
        String privateKey = "MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQDQ/b8SF3jZlfHWsNvN1L4r8pQXQdCV7qjGPkM0dFTyyPx8p8wl5OnN6w6JUKD8LdTVzYvyEjBCTJFfSdVOfEPq89TKjup+oskjSBRSMlxzEfrCmcSk/dSC/H2Ob/RAJa01bTbOxl9mHgWYgh1uU37LXpfX/U3VTtoyvj+Kyw5ffYeZmIbuOl+2Lu1YjJxCBjWsOVE/Re09IWnwQvpqCmmM3fMqDM87O69Y7qIi5fJWdhkj5rkPhCMYtMDJCG/nKzN/HL61ghCQE7aCmfTf/uGY8wpY0WoNXjLnIp9f2OXGyXr79YoQYbYhpe2TbSfPk5/mcdgGK3uNdzllw42WToKDAgMBAAECggEAdRZErzEhTt4YEM0jSG0xYlPUrjb8UpPUUMTfSAsI8MCz3G7yDCT07J4Nldbran2O6X3wMt4H1Y0qQPWPoRozvvV+uUFalTpEcBTY9bgrXXisQcx+hGWFYyFsgpmsgSfao70dYLl5BzA4uFnlfUMgHXZQofzTV3eG/bjixrK+ybX6TCMn1ub+yS3Vq5KW1OcPVaYMP8xIOCZb5tDeCiziuz5yllUEYX+bZtaRuJPek7AxowAtUL4E6nMsSLjCbN4231et5kDifOdES3dwj21rt8kxu+IRh03Jtv9w1mEJAb1HXXd886U13eUTu2reUcUXTBG1OtEi+wocdWn2fBGMaQKBgQDozKnXLrRSIHklonGuZjybLFpyQ1SFpaqCSnCb/cfiRwUgj6uk5FuRZLiLmTgTBXB0EzxwrWJ8vpT2Wt8qsG7mmHfjYWyVnW/n6YYkmzj059rtkMqgcC4QQhpnW40j74v1Ds7EPQan94agyvRadmlhAoa0l8IZJdPYG+/EmgbX/wKBgQDl0aubT+RjxkZAy6eT1FeHZ5ALI/XBVd2T7Hyx4ypEAPIq/6zUiQis3jM5u5GHcP3MelS0A7Q3PvsI7+9y0J2VHZhqpLn2378tvjv+kn/4k/jC9t4RF0UWOLsppfLIGnqLJLUUk4J61U/vF/OJVF9KQQMNFqubs5fdiYJEK8D1fQKBgQCmVLyw01zhJPSKEDObQM7iq+D/rN2yE7jtGJS2z69GHCosppoj2UkXa9hzXYj0BjnfpXLUqv0oVd8G2cyDqsXCGoPmQVCc4Xz4PSCr/P/H8/S3MnGkCiLPWPuWh5Ijb98Wu3q+OUANOMzHC9tk2x/VwUFPvPJgl2dyDBvW45oqLwKBgQCHiaeWmoCM43OtZS54veO9RLOsDlIy6qwaQH+t/daAcrpf55gLZKIMKaO2acvDQD0+aesom4KejnNI6xCh+yzks6afRnUyhvTeSnJhig8VEFfGzAddtwaUu3KOdoN/xjX9d/Gfp/ts6/8PeGW12V+1kC/3eSZOVpW7Hw0HnXJYlQKBgCxsoDQsuYFdigEZPw7LZmSr5vM4SIt1/uFFQKfJ8ac/Ol8xeWN4EJ6EDnoSzxtK5nCCv4DIR++MuTT1pK3jRnNIYppRa4SQ4mOYkl+OFzRD0KUy7kjY3jfAeqM2RQeqAIKrSsyq5/+flL8biYa5TtVU6L1qabyRPPhZS2IOaLJl";
        String publicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0P2/Ehd42ZXx1rDbzdS+K/KUF0HQle6oxj5DNHRU8sj8fKfMJeTpzesOiVCg/C3U1c2L8hIwQkyRX0nVTnxD6vPUyo7qfqLJI0gUUjJccxH6wpnEpP3Ugvx9jm/0QCWtNW02zsZfZh4FmIIdblN+y16X1/1N1U7aMr4/issOX32HmZiG7jpfti7tWIycQgY1rDlRP0XtPSFp8EL6agppjN3zKgzPOzuvWO6iIuXyVnYZI+a5D4QjGLTAyQhv5yszfxy+tYIQkBO2gpn03/7hmPMKWNFqDV4y5yKfX9jlxsl6+/WKEGG2IaXtk20nz5Of5nHYBit7jXc5ZcONlk6CgwIDAQAB";
        String secretDigest = sign(content,privateKey);
        if (verifySignature(content, secretDigest, publicKey)){
            System.out.println("公钥验签通过");
        }else{
            System.out.println("公钥验签失败");
        }
    }

    /**
     * 使用公钥进行验签
     * @param content 内容
     * @param secretDigest 签名
     * @param publicKey 公钥
     * @return
     */
    public static boolean verifySignature(String content, String secretDigest, String publicKey) {
        try {

            byte[] decodedKey = Base64.decodeBase64(publicKey);
            byte[] signData = Base64.decodeBase64(secretDigest);

            if (decodedKey !=null && null != signData) {
                // 生成公钥
                Signature signature = Signature.getInstance(SIGN_ALGORITHMS);
                signature.initVerify(KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(decodedKey)));
                signature.update(content.getBytes("UTF-8"));

                return signature.verify(signData);
            }
        } catch (GeneralSecurityException | IOException e) {
            System.out.println("verifySignature exception");
        } catch (Exception e) {
            System.out.println("verifySignature failure");
        }

        return false;
    }

    /**
     * 使用私钥进行给内容签名
     * @param content 内容
     * @param privateKey 私钥
     * @return
     */
    public static String sign(String content, String privateKey)
    {
        try
        {
            PKCS8EncodedKeySpec priPKCS8    = new PKCS8EncodedKeySpec( Base64.decodeBase64(privateKey) );
            KeyFactory keyf                 = KeyFactory.getInstance("RSA");
            PrivateKey priKey               = keyf.generatePrivate(priPKCS8);

            java.security.Signature signature = java.security.Signature
                    .getInstance(SIGN_ALGORITHMS);

            signature.initSign(priKey);
            signature.update( content.getBytes("UTF-8") );

            byte[] signed = signature.sign();

            return Base64.encodeBase64String(signed);
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }

        return null;
    }
}

验证结果:公钥验签通过
生成RSA秘钥的网址:http://web.chacuo.net/netrsakeypair

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值