RSA加密读取密钥

最近弄des rsa加密算法,碰到了一些问题,分享一下经验,欢迎拍砖。你也许要问为什么读RSA的密钥呢?我这个还真得读密钥,具体原因不说了
看了网上的一些资料,结果发现,很多人都用Object流保存key,然后再读出来。这不是我想要的,privatekey是别人提供给我的,并且只给个pem,于是从网上查了一下,发现这样的代码


BufferedReader br = new BufferedReader(new FileReader( "my-prvkey.pem "));
String s = br.readLine();
String str = " ";
s = br.readLine();
while (s.charAt(0) != ’-’){
str += s + "\r ";
s = br.readLine();
}

问题是根本就不能运行,于是又查了些资料,发现要把pem的文件转换为der的文件,于是找到个命令
openssl pkcs8 -topk8 -inform PEM -outform DER -in rsa_pem.key -out pkcs8_der.key -nocrypt
读取的时候用

File privKeyFile = new File("你要的密钥路径");
DataInputStream dis = new DataInputStream(new FileInputStream(
privKeyFile));
byte[] privKeyBytes = new byte[(int) privKeyFile.length()];
dis.read(privKeyBytes);
dis.close();

然后用PKCS8EncodedKeySpec将其转换,
就ok了,
另外java中RSA好像只支持512以上的。256就报错。好了先写这么多,又有事情了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值