内容简介:首先创建然后初始化密钥对的长度,最低长度512位,并且长度不能低于明文的长度利用
生成密钥对
首先创建 KeyPairGenerator 类的对象,用于生成公钥和私钥对
// 生成公钥和私钥对,基于RSA算法生成对象
KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA");
然后初始化密钥对的长度,最低长度512位,并且长度不能低于明文的长度
// 初始化密钥大小为1024位 keyPairGen.initialize(1024);
利用 keyPairGen 对象生成密钥对,保存在 KeyPair 类中
KeyPair keyPair = keyPairGen.generateKeyPair();
从 keyPair 类中获取公钥和私钥
RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic(); RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();
加密(encrypt)
protected static byte[] encrypt(RSAPublicKey publicKey, byte[] srcBytes) {
if (publicKey != null) {
try {
// Cipher负责完成加密或解密工作,基于RSA
Cipher cipher = Cipher.getInstance(ALGORITHM);
// 根据公钥,对Cipher对象进行初始化
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
// 加密,结果保存进resultBytes,并返回
byte[] resultBytes = cipher.doFinal(srcBytes);
return resultBytes;
} catch (Exception e) {
e.printStackTrace();
}
}
return null;
}
解密(decrypt)
protected static byte[] encrypt(RSAPublicKey publicKey, byte[] srcBytes) {
if (publicKey != null) {
try {
// Cipher负责完成加密或解密工作,基于RSA
Cipher cipher = Cipher.getInstance("RSA");
// 根据公钥,对Cipher对象进行初始化
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
// 加密,结果保存进resultBytes,并返回
byte[] resultBytes = cipher.doFinal(srcBytes);
return resultBytes;
} catch (Exception e) {
e.printStackTrace();
}
}
return null;
}
完整代码
import java.security.*;
import java.security.interfaces.*;
import javax.crypto.*;
public class RSA {
private RSAPublicKey publicKey;
private RSAPrivateKey privateKey;
private byte[] resultBytes;
private final static String ALGORITHM = "RSA";
public RSA() {
try {
String message = "你好,我很喜欢加密算法";
System.out.println("明文是:" + message);
// 生成公钥和私钥对,基于RSA算法生成对象
KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance(ALGORITHM);
// 初始化密钥对生成器,密钥大小为1024位
keyPairGen.initialize(1024);
// 生成一个密钥对,保存在keyPair中
KeyPair keyPair = keyPairGen.generateKeyPair();
// 得到公钥和私钥
publicKey = (RSAPublicKey) keyPair.getPublic();
privateKey = (RSAPrivateKey) keyPair.getPrivate();
// 用公钥加密
byte[] srcBytes = message.getBytes();
resultBytes = RSA.encrypt(publicKey, srcBytes);
String result = new String(resultBytes);
System.out.println("用公钥加密后密文是:" + result);
} catch (Exception e) {
e.printStackTrace();
}
}
protected static byte[] encrypt(RSAPublicKey publicKey, byte[] srcBytes) {
if (publicKey != null) {
try {
// Cipher负责完成加密或解密工作,基于RSA
Cipher cipher = Cipher.getInstance(ALGORITHM);
// 根据公钥,对Cipher对象进行初始化
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
// 加密,结果保存进resultBytes,并返回
byte[] resultBytes = cipher.doFinal(srcBytes);
return resultBytes;
} catch (Exception e) {
e.printStackTrace();
}
}
return null;
}
protected byte[] decrypt(RSAPrivateKey privateKey, byte[] encBytes) {
if (privateKey != null) {
try {
Cipher cipher = Cipher.getInstance(ALGORITHM);
// 根据私钥对Cipher对象进行初始化
cipher.init(Cipher.DECRYPT_MODE, privateKey);
// 解密并将结果保存进resultBytes
byte[] decBytes = cipher.doFinal(encBytes);
return decBytes;
} catch (Exception e) {
e.printStackTrace();
}
}
return null;
}
public static void main(String[] args) {
long rsaStart = System.currentTimeMillis();
RSA rsa = new RSA();
byte[] decBytes = rsa.decrypt(rsa.privateKey, rsa.resultBytes);
String dec = new String(decBytes);
long rsaEnd = System.currentTimeMillis();
System.out.println("用私钥解密后的结果是:" + dec);
System.out.println("共计用时:" + (rsaEnd - rsaStart));
}
}
运行结果见下面的GIF:
以上所述就是小编给大家介绍的《Java实现RSA加密算法》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
自媒体写作,从基本功到实战方法
余老诗 / 清华大学出版社 / 2018-9-1 / 59.00元
《自媒体写作》是一本系统而通俗易懂的自媒体写作指导书。 全书共分为10章,分别从写作基本功、新媒体认知、新媒体传播规律和自媒体作者阅读写作素养以及如何进阶等方面展开,结合简书、公众号、今日头条等主流自媒体所选例文,讲解写作知识和新媒体特点,内容详实,有理有据,非常适合自媒体写作爱好者自学。 尤其值得一提的是,写作基本功部分从原理、方法和技巧三个层面展开论说,让自媒体写作学习者既能从根本......一起来看看 《自媒体写作,从基本功到实战方法》 这本书的介绍吧!