java處理加密文件---RSA加密和解密
public class RSA {
public static void main(String []args)throws Exception
{
String ptext = "he";
//獲取公鑰生成參數
KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA");
kpg.initialize(1024);
KeyPair keyPair = kpg.genKeyPair();
RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic();
RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();
System.out.println("公共碼"+publicKey.getModulus().toString());
byte[] ptexts = ptext.getBytes("UTF8");
BigInteger m = new BigInteger(ptexts);
BigInteger c = m.modPow(publicKey.getPublicExponent(), publicKey.getModulus());
System.out.println("密文"+c);
//System.out.println("d:"+privateKey.getPrivateExponent());
System.out.println("私密碼"+privateKey.getModulus());
BigInteger jm=c.modPow(privateKey.getPrivateExponent(), privateKey.getModulus());
System.out.println("解碼數據"+jm);
byte[] mt =jm.toByteArray();
System.out.print("解碼結果");
for(int i=0;i<mt.length;i++){
System.out.print((char)mt[i]);
}
}
}</pre>
本文由用戶 openkk 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!