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就报错。好了先写这么多,又有事情了

你可能感兴趣的:(算法)