rsa算法举例_RSA算法实例 - 上班不要玩手机的个人空间 - OSCHINA - 中文开源技术交流社区...

import java.io.File;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.ObjectInputStream;

import java.io.ObjectOutputStream;

import java.security.KeyPair;

import java.security.KeyPairGenerator;

import java.security.NoSuchAlgorithmException;

import java.security.PrivateKey;

import java.security.PublicKey;

import java.util.Date;

import javax.crypto.Cipher;

import org.apache.commons.codec.binary.Base64;

public class EncryptionUtil {

/**

* String to hold name of the encryption algorithm.

*/

public static final String ALGORITHM = "RSA";

/**

* String to hold the name of the private key file.

*/

public static final String PRIVATE_KEY_FILE = "C:/keys/private.key";

/**

* String to hold name of the public key file.

*/

public static final String PUBLIC_KEY_FILE = "C:/keys/public.key";

/**

* Generate key which contains a pair of private and public key using 1024

* bytes. Store the set of keys in Prvate.key and Public.key files.

*

* [@throws](https://my.oschina.net/throws) NoSuchAlgorithmException

* [@throws](https://my.oschina.net/throws) IOException

* [@throws](https://my.oschina.net/throws) FileNotFoundException

*/

public static void generateKey() {

try {

final KeyPairGenerator keyGen = KeyPairGenerator.getInstance(ALGORITHM);

keyGen.initialize(1024);

final KeyPair key = keyGen.generateKeyPair();

File privateKeyFile = new File(PRIVATE_KEY_FILE);

File publicKeyFile = new File(PUBLIC_KEY_FILE);

// Create files to store public and private key

if (privateKeyFile.getParentFile() != null) {

privateKeyFile.getParentFile().mkdirs();

}

privateKeyFile.createNewFile();

if (publicKeyFile.getParentFile() != null) {

publicKeyFile.getParentFile().mkdirs();

}

publicKeyFile.createNewFile();

// Saving the Public key in a file

ObjectOutputStream publicKeyOS = new ObjectOutputStream(

new FileOutputStream(publicKeyFile));

publicKeyOS.writeObject(key.getPublic());

publicKeyOS.close();

// Saving the Private key in a file

ObjectOutputStream privateKeyOS = new ObjectOutputStream(

new FileOutputStream(privateKeyFile));

privateKeyOS.writeObject(key.getPrivate());

privateKeyOS.close();

} catch (Exception e) {

e.printStackTrace();

}

}

/**

* The method checks if the pair of public and private key has been generated.

*

* [@return](https://my.oschina.net/u/556800) flag indicating if the pair of keys were generated.

*/

public static boolean areKeysPresent() {

File privateKey = new File(PRIVATE_KEY_FILE);

File publicKey = new File(PUBLIC_KEY_FILE);

if (privateKey.exists() && publicKey.exists()) {

return true;

}

return false;

}

/**

* Encrypt the plain text using public key.

*

* [@param](https://my.oschina.net/u/2303379) text

* : original plain text

* @param key

* :The public key

* @return Encrypted text

* @throws java.lang.Exception

*/

public static byte[] encrypt(String text, PublicKey key) {

byte[] cipherText = null;

try {

// get an RSA cipher object and print the provider

final Cipher cipher = Cipher.getInstance(ALGORITHM);

// encrypt the plain text using the public key

cipher.init(Cipher.ENCRYPT_MODE, key);

cipherText = cipher.doFinal(text.getBytes());

} catch (Exception e) {

e.printStackTrace();

}

return cipherText;

}

/**

* Decrypt text using private key.

*

* @param text

* :encrypted text

* @param key

* :The private key

* @return plain text

* @throws java.lang.Exception

*/

public static String decrypt(byte[] text, PrivateKey key) {

byte[] dectyptedText = null;

try {

// get an RSA cipher object and print the provider

final Cipher cipher = Cipher.getInstance(ALGORITHM);

// decrypt the text using the private key

cipher.init(Cipher.DECRYPT_MODE, key);

dectyptedText = cipher.doFinal(text);

} catch (Exception ex) {

ex.printStackTrace();

}

return new String(dectyptedText);

}

/**

* Test the EncryptionUtil

*/

public static void main(String[] args) {

try {

// Check if the pair of keys are present else generate those.

if (!areKeysPresent()) {

// Method generates a pair of keys using the RSA algorithm and stores it

// in their respective files

generateKey();

}

long timestamp =new Date().getTime();

String originalText = "18036085116,123456,"+String.valueOf(timestamp);

ObjectInputStream inputStream = null;

// Encrypt the string using the public key

inputStream = new ObjectInputStream(new FileInputStream(PUBLIC_KEY_FILE));

final PublicKey publicKey = (PublicKey) inputStream.readObject();

final byte[] cipherText = encrypt(originalText, publicKey);

String enBytesStr =Base64.encodeBase64String(cipherText);

System.out.println(enBytesStr);

// Decrypt the cipher text using the private key.

inputStream = new ObjectInputStream(new FileInputStream(PRIVATE_KEY_FILE));

final PrivateKey privateKey = (PrivateKey) inputStream.readObject();

final String plainText = decrypt(cipherText, privateKey);

inputStream.close();

// Printing the Original, Encrypted and Decrypted Text

System.out.println("Original: " + originalText);

System.out.println("Encrypted: " +cipherText.toString());

System.out.println("Decrypted: " + plainText);

} catch (Exception e) {

e.printStackTrace();

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值