RSA加密算法java簡單實(shí)現(xiàn)方法(必看)
更新時(shí)間:2016年09月16日 13:47:07 投稿:jingxian
下面小編就為大家?guī)硪黄猂SA加密算法java簡單實(shí)現(xiàn)方法(必看)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
簡單完整的代碼,通過這個(gè)代碼你將對(duì)RSA加密算法在Java中的實(shí)現(xiàn)方法有一個(gè)初步的了解,這個(gè)類,你可以直接使用,水平高的,就自己修改完善下代碼。
package security;
import java.security.*;
import java.security.spec.*;
import java.security.interfaces.*;
import javax.crypto.spec.*;
import javax.crypto.interfaces.*;
import java.io.*;
import java.math.*;
public class RSADemo {
public RSADemo() {
}
public static void generateKey() {
try {
KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA");
kpg.initialize(1024);
KeyPair kp = kpg.genKeyPair();
PublicKey pbkey = kp.getPublic();
PrivateKey prkey = kp.getPrivate();
// 保存公鑰
FileOutputStream f1 = new FileOutputStream("pubkey.dat");
ObjectOutputStream b1 = new ObjectOutputStream(f1);
b1.writeObject(pbkey);
// 保存私鑰
FileOutputStream f2 = new FileOutputStream("privatekey.dat");
ObjectOutputStream b2 = new ObjectOutputStream(f2);
b2.writeObject(prkey);
} catch (Exception e) {
}
}
public static void encrypt() throws Exception {
String s = "Hello World!";
// 獲取公鑰及參數(shù)e,n
FileInputStream f = new FileInputStream("pubkey.dat");
ObjectInputStream b = new ObjectInputStream(f);
RSAPublicKey pbk = (RSAPublicKey) b.readObject();
BigInteger e = pbk.getPublicExponent();
BigInteger n = pbk.getModulus();
System.out.println("e= " + e);
System.out.println("n= " + n);
// 獲取明文m
byte ptext[] = s.getBytes("UTF-8");
BigInteger m = new BigInteger(ptext);
// 計(jì)算密文c
BigInteger c = m.modPow(e, n);
System.out.println("c= " + c);
// 保存密文
String cs = c.toString();
BufferedWriter out =
new BufferedWriter(
new OutputStreamWriter(new FileOutputStream("encrypt.dat")));
out.write(cs, 0, cs.length());
out.close();
}
public static void decrypt() throws Exception {
// 讀取密文
BufferedReader in =
new BufferedReader(
new InputStreamReader(new FileInputStream("encrypt.dat")));
String ctext = in.readLine();
BigInteger c = new BigInteger(ctext);
// 讀取私鑰
FileInputStream f = new FileInputStream("privatekey.dat");
ObjectInputStream b = new ObjectInputStream(f);
RSAPrivateKey prk = (RSAPrivateKey) b.readObject();
BigInteger d = prk.getPrivateExponent();
// 獲取私鑰參數(shù)及解密
BigInteger n = prk.getModulus();
System.out.println("d= " + d);
System.out.println("n= " + n);
BigInteger m = c.modPow(d, n);
// 顯示解密結(jié)果
System.out.println("m= " + m);
byte[] mt = m.toByteArray();
System.out.println("PlainText is ");
for (int i = 0; i < mt.length; i++) {
System.out.print((char) mt[i]);
}
}
public static void main(String args[]) {
try {
generateKey();
encrypt();
decrypt();
} catch (Exception e) {
System.out.println(e.toString());
}
}
}
以上這篇RSA加密算法java簡單實(shí)現(xiàn)方法(必看)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- 分享Java常用幾種加密算法(四種)
- java自帶的MessageDigest實(shí)現(xiàn)文本的md5加密算法
- 使用java自帶des加密算法實(shí)現(xiàn)文件加密和字符串加密
- java實(shí)現(xiàn)MD5加密算法的實(shí)例代碼
- java實(shí)現(xiàn)的AES加密算法完整實(shí)例
- java異或加密算法
- 詳解Java中實(shí)現(xiàn)SHA1與MD5加密算法的基本方法
- 利用JAVA實(shí)現(xiàn)DES加密算法
- JAVA實(shí)現(xiàn)caesar凱撒加密算法
- java實(shí)現(xiàn)同態(tài)加密算法的實(shí)例代碼
相關(guān)文章
java的Object里wait()實(shí)現(xiàn)原理講解
這篇文章主要介紹了java的Object里wait()實(shí)現(xiàn)原理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
springboot下使用shiro自定義filter的個(gè)人經(jīng)驗(yàn)分享
這篇文章主要介紹了springboot下使用shiro自定義filter的個(gè)人經(jīng)驗(yàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
springmvc+mybatis 做分頁sql 語句實(shí)例代碼
本文通過一段實(shí)例代碼給大家介紹了springmvc+mybatis 做分頁sql 語句的方法,代碼簡單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-07-07

