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