java rsa私钥长度,Java中的RSA密钥大小小于512位

是的,但您必须使用其他提供商。 当您尝试使用384位RSA密钥时,Sun RSAKeyFactory ( KeyFactory的基础服务提供程序实现)和RSAKeyPairGenerator返回异常。

正确安装Bouncy Castle提供程序后,这将有效:Security.addProvider(new BouncyCastleProvider());

KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA", "BC");

kpg.initialize(384);

KeyPair kp = kpg.generateKeyPair();

PublicKey genPub = kp.getPublic();

byte[] enc = genPub.getEncoded();

KeyFactory kf = KeyFactory.getInstance("RSA", "BC");

X509EncodedKeySpec ks = new X509EncodedKeySpec(enc);

PublicKey decPub = kf.generatePublic(ks);

Signature sig = Signature.getInstance("SHA1withRSA", "BC");

sig.initVerify(decPub);

byte[] faultySig = new byte[384 / Byte.SIZE];

boolean verifies = sig.verify(faultySig);

System.out.println(verifies + " for " + decPub.getAlgorithm());

请注意,由于KeyFactory生成的密钥类型,即使未指定"BC" , Signature实例的init方法也将默默使用Bouncy Castle提供程序。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值