You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

Java RMI应用中适配RSA密钥的签名算法选型求助

解决SignedObject使用RSA密钥时的InvalidKeyException问题

你遇到的这个错误原因很明确:DSA签名算法和RSA密钥完全不兼容。DSA是一套独立的数字签名体系,只能搭配DSA类型的密钥使用,而你传入的是RSA私钥(RSAPrivateCrtKeyImpl),签名引擎找不到能适配的密钥提供者,自然就抛出了InvalidKeyException

适配RSA密钥的签名算法选项

针对RSA密钥,你需要选择基于RSA的签名算法,JDK默认就提供了几种常用且可靠的选项:

  • SHA256withRSA:最推荐的通用方案,结合SHA-256哈希算法与RSA签名,安全性满足绝大多数业务场景,兼容性也拉满
  • SHA512withRSA:更高安全级别的组合,适合对数据完整性、抗篡改要求极高的敏感业务场景
  • SHA1withRSA:仅建议用于旧系统兼容场景,SHA-1哈希算法的安全性已不足,不推荐在新开发的应用中使用

代码修改示例

把你创建SignedObject时的签名算法替换成上述RSA适配的算法即可,比如:

// 假设你已获取到合法的RSA私钥
PrivateKey rsaPrivateKey = ...;
// 初始化SHA256withRSA签名实例
Signature rsaSignature = Signature.getInstance("SHA256withRSA");
// 创建带RSA签名的SignedObject
SignedObject signedTweet = new SignedObject(yourTweetObject, rsaPrivateKey, rsaSignature);

这样修改后,签名引擎就能正确识别你的RSA私钥,不会再抛出密钥不支持的异常了。

内容的提问来源于stack exchange,提问作者Astarno

火山引擎 最新活动