我有一个来自外部源(Android Store)的 bse64 编码字符串公钥,我需要用它来验证签名内容。如何将字符串转换为 java.security.PublicKey 接口的实例。如果这有什么区别的话,我正在使用 Java 6。
密钥(可能)是使用标准 java lib 而不是 bouncy castle 生成的(它来自远程团队,所以我不确定)。他们的示例代码表示使用 Security.generatePublicKey(base64EncodedPublicKey);但标准java中的Security对象没有这样的方法。
上述答案的代码
public static PublicKey getKey(String key){
try{
byte[] byteKey = Base64.decode(key.getBytes(), Base64.DEFAULT);
X509EncodedKeySpec X509publicKey = new X509EncodedKeySpec(byteKey);
KeyFactory kf = KeyFactory.getInstance("RSA");
return kf.generatePublic(X509publicKey);
}
catch(Exception e){
e.printStackTrace();
}
return null;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)