RSA加密的方式和解密方式实现方法(推荐)
RSAsecurity.java
packagecom.mstf.rsa;
importjava.security.KeyFactory;
importjava.security.KeyPair;
importjava.security.KeyPairGenerator;
importjava.security.PrivateKey;
importjava.security.PublicKey;
importjava.security.interfaces.RSAPrivateKey;
importjava.security.interfaces.RSAPublicKey;
importjava.security.spec.PKCS8EncodedKeySpec;
importjava.security.spec.X509EncodedKeySpec;
importjavax.crypto.Cipher;
importcom.sun.org.apache.xerces.internal.impl.dv.util.Base64;
/*RSA工具类。提供加密,解密,生成密钥对等方法。
RSA加密原理概述
RSA的安全性依赖于大数的分解,公钥和私钥都是两个大素数(大于100的十进制位)的函数。
据猜测,从一个密钥和密文推断出明文的难度等同于分解两个大素数的积
密钥的产生:
1.选择两个大素数p,q,计算n=p*q;
2.随机选择加密密钥e,要求e和(p-1)*(q-1)互质
3.利用Euclid算法计算解密密钥d,使其满足e*d=1(mod(p-1)*(q-1))(其中n,d也要互质)
4:至此得出公钥为(n,e)私钥为(n,d)
RSA速度
*由于进行的都是大数计算,使得RSA最快的情况也比DES慢上100倍,无论是软件还是硬件实现。
*速度一直是RSA的缺陷。一般来说只用于少量数据加密。*/
publicclassRSAsecurity{
publicstaticStringsrc="admin";
publicvoidpriENpubDE(){
try{
//初始化秘钥
KeyPairGeneratorkeyPairGenerator=KeyPairGenerator.getInstance("RSA");
//秘钥长度
keyPairGenerator.initialize(1024);
//初始化秘钥对
KeyPairkeyPair=keyPairGenerator.generateKeyPair();
//公钥
RSAPublicKeyrsaPublicKey=(RSAPublicKey)keyPair.getPublic();
//私钥
RSAPrivateKeyrsaPrivateKey=(RSAPrivateKey)keyPair.getPrivate();
//2.私钥加密,公钥解密----加密
//生成私钥
PKCS8EncodedKeySpecpkcs8EncodedKeySpec=newPKCS8EncodedKeySpec(rsaPrivateKey.getEncoded());
KeyFactorykeyFactory=KeyFactory.getInstance("RSA");
PrivateKeyprivateKey=keyFactory.generatePrivate(pkcs8EncodedKeySpec);
//Cipher类为加密和解密提供密码功能,通过getinstance实例化对象
Ciphercipher=Cipher.getInstance("RSA");
//初始化加密
cipher.init(Cipher.ENCRYPT_MODE,privateKey);
byte[]result=cipher.doFinal(src.getBytes());
System.out.println("私钥加密,公钥解密----加密:"+Base64.encode(result));
//3.私钥加密,公钥解密----解密
//生成公钥
X509EncodedKeySpecx509EncodedKeySpec=newX509EncodedKeySpec(rsaPublicKey.getEncoded());
keyFactory=KeyFactory.getInstance("RSA");
PublicKeypublicKey=keyFactory.generatePublic(x509EncodedKeySpec);
cipher=Cipher.getInstance("RSA");
//初始化解密
cipher.init(Cipher.DECRYPT_MODE,publicKey);
result=cipher.doFinal(result);
System.out.println("私钥加密,公钥解密----解密:"+newString(result));
}catch(Exceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}
}
publicvoidpubENpriDE(){
try{
//1.初始化秘钥
KeyPairGeneratorkeyPairGenerator=KeyPairGenerator.getInstance("RSA");
//秘钥长度
keyPairGenerator.initialize(512);
//初始化秘钥对
KeyPairkeyPair=keyPairGenerator.generateKeyPair();
//公钥
RSAPublicKeyrsaPublicKey=(RSAPublicKey)keyPair.getPublic();
//私钥
RSAPrivateKeyrsaPrivateKey=(RSAPrivateKey)keyPair.getPrivate();
//2.公钥加密,私钥解密----加密
X509EncodedKeySpecx509EncodedKeySpec=newX509EncodedKeySpec(rsaPublicKey.getEncoded());
KeyFactorykeyFactory=KeyFactory.getInstance("RSA");
PublicKeypublicKey=keyFactory.generatePublic(x509EncodedKeySpec);
//初始化加密
//Cipher类为加密和解密提供密码功能,通过getinstance实例化对象
Ciphercipher=Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE,publicKey);
//加密字符串
byte[]result=cipher.doFinal(src.getBytes());
System.out.println("公钥加密,私钥解密----加密:"+Base64.encode(result));
//3.公钥加密,私钥解密-----解密
PKCS8EncodedKeySpecpkcs8EncodedKeySpec=newPKCS8EncodedKeySpec(rsaPrivateKey.getEncoded());
keyFactory=KeyFactory.getInstance("RSA");
PrivateKeyprivateKey=keyFactory.generatePrivate(pkcs8EncodedKeySpec);
//初始化解密
cipher.init(Cipher.DECRYPT_MODE,privateKey);
//解密字符串
result=cipher.doFinal(result);
System.out.println("公钥加密,私钥解密-----解密:"+newString(result));
}catch(Exceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}
}
}
RSAtest.java
packagecom.mstf.rsa;
importcom.mstf.rsa.RSAsecurity;
publicclassRSAtest{
publicstaticvoidmain(String[]args){
RSAsecurityrsAsecurity=newRSAsecurity();
System.out.println("私钥加密公钥解密例:");
rsAsecurity.priENpubDE();
System.out.println("公钥加密私钥解密例:");
rsAsecurity.pubENpriDE();
}
}
以上这篇RSA加密的方式和解密方式实现方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。