java dh_非对称式加密在JAVA中的实现(DH加密) - java实现非对称加密算法的过程...

JAVA实现非对称加密:DH与RSA详解
本文详细介绍了如何在JAVA中实现非对称加密,包括使用DH算法和RSA算法。通过实例展示了密钥生成、加密解密过程,帮助理解非对称加密的工作原理。

4. 非对称式加密在JAVA中的实现(DH加密):

[java] view plain copypublic class DH {

private static String src=“security with DH”;

public static void main(String[] args){

jdkDH();

}

public static void jdkDH(){

try {

//初始化发送方密钥

KeyPairGenerator senderKeyPairGenerator=KeyPairGenerator.getInstance(“DH”);

senderKeyPairGenerator.initialize(512);

KeyPair senderKeyPair=senderKeyPairGenerator.generateKeyPair();

byte[] senderPublicKeyEnc=senderKeyPair.getPublic().getEncoded();

//初始化接收方密钥

KeyFactory receiverKeyFactory=KeyFactory.getInstance(“DH”);

X509EncodedKeySpec x509EncodedKeySpec=new X509EncodedKeySpec(senderPublicKeyEnc);

PublicKey receiverPublicKey=receiverKeyFactory.generatePublic(x509EncodedKeySpec);

DHParameterSpec dhParameterSpec=((DHPublicKey)receiverPublicKey).getParams();

KeyPairGenerator receiverKeyPairGenerator=KeyPairGenerator.getInstance(“DH”);

receiverKeyPairGenerator.initialize(dhParameterSpec);

KeyPair receiverKeyPair=receiverKeyPairGenerator.generateKeyPair();

PrivateKey receiverPrivateKey=receiverKeyPair.getPrivate();

byte[] receiverPublicKeyEnc =receiverKeyPair.getPublic().getEncoded();

//密钥构建

KeyAgreement receiverKeyAgreement = KeyAgreement.getInstance(“DH”);

receiverKeyAgreement.init(receiverPrivateKey);

receiverKeyAgreement.doPhase(receiverPublicKey, true);

SecretKey receiverDesKey=receiverKeyAgreement.generateSecret(“DES”);

KeyFactory senderKeyFactory=KeyFactory.getInstance(“DH”);

x509EncodedKeySpec=new X509EncodedKeySpec(receiverPublicKeyEnc);

PublicKey senderPublicKey=senderKeyFactory.generatePublic(x509EncodedKeySpec);

KeyAgreement senderKeyAgreement=KeyAgreement.getInstance(“DH”);

senderKeyAgreement.init(senderKeyPair.getPrivate());

senderKeyAgreement.doPhase(senderPublicKey, true);

SecretKey senderDesKey=senderKeyAgreement.generateSecret(“DES”);

if(Objects.equals(receiverDesKey,senderDesKey)){

System.out.println(“双方密钥相同”);

}

//加密

Cipher cipher=Cipher.getInstance(“DES”);

cipher.init(Cipher.ENCRYPT_MODE,senderDesKey);

byte[] result=cipher.doFinal(src.getBytes());

System.out.println(“jdk dh encrypt:”+Base64.encodeToString(result,1));

//解密

cipher=Cipher.getInstance(“DES”);

cipher.init(Cipher.DECRYPT_MODE,receiverDesKey);

result=cipher.doFinal(result);

System.out.println(“jdk dh encrypt:”+new String(result));

} catch (Exception e) {

e.printStackTrace();

}

}

}

e9f22f61c109a7b47ff2b05f70b1843a.png

5. 非对称式加密在JAVA中的实现(RSA加密):

[java] view plain copypublic class RSA {

private static String src=“security with rsa”;

public static void main(String[] args){

jdkRSA();

}

public static void jdkRSA(){

try {

//初始化密钥

KeyPairGenerator keyPairGenerator=KeyPairGenerator.getInstance(“RSA”);

keyPairGenerator.initialize(512);//64的整倍数,512~65536

KeyPair keyPair=keyPairGenerator.generateKeyPair();

RSAPrivateKey rsaPrivateKey= (RSAPrivateKey) keyPair.getPrivate();

RSAPublicKey rsaPublicKey= (RSAPublicKey) keyPair.getPublic();

System.out.println(“Public key:”+ Base64.encodeToString(rsaPrivateKey.getEncoded(),1));

System.out.println(“Private key:”+ Base64.encodeToString(rsaPrivateKey.getEncoded(),1));

//私钥加密,公钥解密——加密

PKCS8EncodedKeySpec pkcs8EncodedKeySpec=new PKCS8EncodedKeySpec(rsaPrivateKey.getEncoded());

KeyFactory keyFactory=KeyFactory.getInstance(“RSA”);

PrivateKey privateKey=keyFactory.generatePrivate(pkcs8EncodedKeySpec);

Cipher cipher=Cipher.getInstance(“RSA”);

cipher.init(Cipher.ENCRYPT_MODE, privateKey);

byte[] result=cipher.doFinal(src.getBytes());

System.out.println(“私钥加密,公钥解密——加密:”+Base64.encodeToString(result,1));

//私钥加密,公钥解密——解密

X509EncodedKeySpec x509EncodedKeySpec=new X509EncodedKeySpec(rsaPublicKey.getEncoded());

keyFactory=KeyFactory.getInstance(“RSA”);

PublicKey publicKey=keyFactory.generatePublic(x509EncodedKeySpec);

cipher=Cipher.getInstance(“RSA”);

cipher.init(Cipher.DECRYPT_MODE,publicKey);

result=cipher.doFinal(result);

System.out.println(new String(result));

//公钥加密,私钥解密——加密

x509EncodedKeySpec=new X509EncodedKeySpec(rsaPublicKey.getEncoded());

keyFactory=KeyFactory.getInstance(“RSA”);

publicKey=keyFactory.generatePublic(x509EncodedKeySpec);

cipher=Cipher.getInstance(“RSA”);

cipher.init(Cipher.ENCRYPT_MODE,publicKey);

result=cipher.doFinal(src.getBytes());

System.out.println(“钥加密,私钥解密——加密:”+Base64.encodeToString(result,1));

//公钥加密,私钥解密——解密

pkcs8EncodedKeySpec=new PKCS8EncodedKeySpec(rsaPrivateKey.getEncoded());

keyFactory=KeyFactory.getInstance(“RSA”);

privateKey=keyFactory.generatePrivate(pkcs8EncodedKeySpec);

cipher=Cipher.getInstance(“RSA”);

cipher.init(Cipher.DECRYPT_MODE,privateKey);

cipher.doFinal(result);

System.out.println(“公钥加密,私钥解密——解密:” + Base64.encodeToString(result, 1));

} catch (Exception e) {

e.printStackTrace();

}

}

}

6560eb60d8cba338034a6ff3eeb7fdf3.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值