English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
이 코드는 RSA 암호화 알고리즘의 Java에서의 구현 방법에 대한 기본적인 이해를 제공합니다. 이 클래스는 바로 사용할 수 있으며, 높은 수준의 사용자는 코드를 수정하여 완성할 수 있습니다.
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!"; // 공개키 및 파라미터 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); // 비밀문자 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); // private 키 읽기 FileInputStream f = new FileInputStream("privatekey.dat"); ObjectInputStream b = new ObjectInputStream(f); RSAPrivateKey prk = (RSAPrivateKey) b.readObject(); BigInteger d = prk.getPrivateExponent(); // private 키 매개변수 및 해제 획득 BigInteger n = prk.getModulus(); System.out.println("d= "); + d); System.out.println("n= "); + n); BigInteger m = c.modPow(d, n); // 해제 결과 표시 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 간단한 구현 방법(빨리 보세요)는 편집자가 여러분에게 공유한 모든 내용입니다. 여러분에게 참고가 되길 바라며, 다들 나아가는 강의를 많이 지지해 주시길 바랍니다.