最近弄des rsa加密算法,碰到了一些问题,分享一下经验,欢迎拍砖。你也许要问为什么读RSA的密钥呢?我这个还真得读密钥,具体原因不说了
看了网上的一些资料,结果发现,很多人都用Object流保存key,然后再读出来。这不是我想要的,privatekey是别人提供给我的,并且只给个pem,于是从网上查了一下,发现这样的代码
问题是根本就不能运行,于是又查了些资料,发现要把pem的文件转换为der的文件,于是找到个命令
openssl pkcs8 -topk8 -inform PEM -outform DER -in rsa_pem.key -out pkcs8_der.key -nocrypt
读取的时候用
然后用PKCS8EncodedKeySpec将其转换,
就ok了,
另外java中RSA好像只支持512以上的。256就报错。好了先写这么多,又有事情了
看了网上的一些资料,结果发现,很多人都用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就报错。好了先写这么多,又有事情了