使用Rsa的私钥签名的时候,遇到一个坑。
因为私钥是python使用的,用的pcks1格式,然后java使用pcks8生成秘钥的时候就报错:
algid parse error, not a sequence
网上有很多解决方案,但是比较之后,最方便,最快速的方案是,转换格式,把PKCS1转成PKCS8,使用的工具是支付宝的转换工具,下载地址:https://docs.open.alipay.com/291/106097/
使用的生成签名的代码如下:
public static String rsaSignHex(String content, String privateKey,String signType) {
try {
PKCS8EncodedKeySpec priPKCS8 = new PKCS8EncodedKeySpec( Base64.decode(privateKey) );
KeyFactory keyf = KeyFactory.getInstance("RSA");
PrivateKey priKey = keyf.generatePrivate(priPKCS8);//privateKey格式不会,这儿会crash
java.security.Signature signature = java.security.Signature.getInstance(signType);// "SHA-256" "SHA1WithRSA" SHA256withRSA
signature.initSign(priKey);
signature.update( content.getBytes());
byte[] signed = signature.sign();
return bytesToHex(signed);
}catch (Exception e) {
e.printStackTrace();
}
return null;
}
本文介绍了一种解决使用Rsa私钥进行签名时遇到的问题的方法。问题源于私钥格式不匹配,即Python中使用的PKCS1格式与Java期望的PKCS8格式不符。文章提供了一个简便快捷的解决方案:利用支付宝提供的工具将私钥从PKCS1转换为PKCS8格式,并给出了具体的Java签名实现代码。
1465

被折叠的 条评论
为什么被折叠?



