algid parse error, not a sequence错误

先说下这个错误的英文解释吧,parse error,not a sequence比较简单,就是说解析错误,不是一个sequence(我认为可以理解为是字符串,当然最好说成是“序列”吧)。那么问题来了——algid是什么意思?百度、谷歌翻译了很多,也没有找到合理的解释!不过我查了下字典,对algid解释为(发烧前)发冷的,寒冷的; 是一个形容词,那么名字就是这个error了。我理解的意思是:说明这个错误很可怕,就是和致命错误差不多吧;
接下来走入正题:这个错误到底是怎么回事?
网上很多解释都是说私钥的格式不是PKCS#8而导致的,但是我负责的两个项目中的代码都是:

            byte[] buffer = Base64.decodeBase64(privateKeyStr);
            PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(buffer);
            KeyFactory keyFactory = KeyFactory.getInstance("RSA");
            privateKey = keyFactory.generatePrivate(keySpec);

如此来生成私钥对象的!方法没有什么差别,单结果是一个成功一个失败!失败的就是报这个错误,所以我觉得原因不是这里!

最终,我在Stack Overflow找到了答案(不得不说老外真厉害,哈哈哈)!

java.security.Security.addProvider(
         new org.bouncycastle.jce.provider.BouncyCastleProvider()
);

在获取私钥之前,调用一下这个方法,就可以了!其实就是提供服务的!想要了解具体的解释,可以去看下这个博客:http://blog.csdn.net/innost/article/details/44081147

猜你喜欢

转载自blog.csdn.net/ls0111/article/details/77533768