java 加密 聊天_java 实现加密

packagecrypt;importjava.security.InvalidKeyException;importjava.security.KeyPair;importjava.security.KeyPairGenerator;importjava.security.NoSuchAlgorithmException;importjava.security.interfaces.RSAPrivateKey;importjava.security.interfaces.RSAPublicKey;importjavax.crypto.BadPaddingException;importjavax.crypto.Cipher;importjavax.crypto.IllegalBlockSizeException;importjavax.crypto.NoSuchPaddingException;public classRSAcrypt {/*** 加密

*@parampublicKey

*@paramsrcBytes

*@return*@throwsNoSuchAlgorithmException

*@throwsNoSuchPaddingException

*@throwsInvalidKeyException

*@throwsIllegalBlockSizeException

*@throwsBadPaddingException*/

protected byte[] encrypt(RSAPublicKey publicKey,byte[] srcBytes) throwsNoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException{if(publicKey!=null){//Cipher负责完成加密或解密工作,基于RSA

Cipher cipher = Cipher.getInstance("RSA");//根据公钥,对Cipher对象进行初始化

cipher.init(Cipher.ENCRYPT_MODE, publicKey);byte[] resultBytes =cipher.doFinal(srcBytes);returnresultBytes;

}return null;

}/*** 解密

*@paramprivateKey

*@paramsrcBytes

*@return*@throwsNoSuchAlgorithmException

*@throwsNoSuchPaddingException

*@throwsInvalidKeyException

*@throwsIllegalBlockSizeException

*@throwsBadPaddingException*/

protected byte[] decrypt(RSAPrivateKey privateKey,byte[] srcBytes) throwsNoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException{if(privateKey!=null){//Cipher负责完成加密或解密工作,基于RSA

Cipher cipher = Cipher.getInstance("RSA");//根据公钥,对Cipher对象进行初始化

cipher.init(Cipher.DECRYPT_MODE, privateKey);byte[] resultBytes =cipher.doFinal(srcBytes);returnresultBytes;

}return null;

}/***@paramargs

*@throwsNoSuchAlgorithmException

*@throwsBadPaddingException

*@throwsIllegalBlockSizeException

*@throwsNoSuchPaddingException

*@throwsInvalidKeyException*/

public static void main(String[] args) throwsNoSuchAlgorithmException, InvalidKeyException, NoSuchPaddingException, IllegalBlockSizeException, BadPaddingException {

RSAcrypt rsa= newRSAcrypt();

String msg= "郭XX-精品相声";//KeyPairGenerator类用于生成公钥和私钥对,基于RSA算法生成对象

KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA");//初始化密钥对生成器,密钥大小为1024位

keyPairGen.initialize(1024);//生成一个密钥对,保存在keyPair中

KeyPair keyPair =keyPairGen.generateKeyPair();//得到私钥

RSAPrivateKey privateKey =(RSAPrivateKey)keyPair.getPrivate();//得到公钥

RSAPublicKey publicKey =(RSAPublicKey)keyPair.getPublic();//用公钥加密

byte[] srcBytes =msg.getBytes();byte[] resultBytes =rsa.encrypt(publicKey, srcBytes);//用私钥解密

byte[] decBytes =rsa.decrypt(privateKey, resultBytes);

System.out.println("明文是:" +msg);

System.out.println("加密后是:" + newString(resultBytes));

System.out.println("解密后是:" + newString(decBytes));

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
先运行safechat包里的greetigserver.class,之后运行greetingclient.class即可。 如遇报错,请参考:https://blog.csdn.net/fengzun_yi/article/details/104497160 实现过程: 1. 采用TCP通信协议完成接收者发送者双方的消息传递。 2. 利用Diffie-Hellman密钥交换协议生成对称加密通信的通信密钥。 3. 为防止中间人攻击,采用RSA非对称加密算法协助DH算法完成密钥交换。具体过程如下: a. 接收者与发送者双方各自利用RSA算法生成自己的公私钥,并生成数字证书,并在一个CA进行认证。 b. 在DH密钥交换阶段,A生成A的DH协商密钥用于发送给B,该密钥与接收方私钥生成最终通信密钥。发送DH密钥时,A先用自己的私钥加密DH协商密钥,再去CA获得一个真实的B的公钥,用B的公钥对加密过的协商密钥再做一次加密,发送给B。(因为是用B的公钥加密过,只有B有B的私钥,所以接收信息只有B自己可以解密查看,又因为是用A的私钥加密过的,只有A有A的私钥,所以只有用A的公钥可以进行解密,所以可以保证协商密钥确实是A发送过来的,而且发送的信息也无法被中间人解密。)B收到信息之后,先用自己的私钥解密,然后去CA获得A的公钥再对消息解密一次,获得A的DH密钥。B发给A的过程同上。 c. 之后双方执行DH生成本地密钥的过程。A利用B发送过来的密钥和A的DH私钥生成通信密钥。B利用A发送过来的密钥和B的DH私钥生成通信密钥。根据DH原理,两者生成的通信密钥是相同的。 4. 利用上一步生成的通信密钥,采用AES对称加密算法进行加密通信。 为了方便起见,并没用对A和B双方进行颁发证书的操作,A的公钥默认B已经从CA获得,B的公钥默认A已经从CA获得。并且采用java控制台交互,仅仅为演示原理及简单效果。
Java中的加密类Cipher是一个非常重要的类,用于加密和解密数据。它是Java Cryptography Architecture (JCA)的一部分,提供了许多加密算法的实现,如DES、AES、RSA等。下面是Cipher类的使用方法: 1. 创建Cipher对象:Cipher对象是通过调用Cipher.getInstance()方法创建的。需要传入一个加密算法的名称,如AES、DES等。 ```java Cipher cipher = Cipher.getInstance("AES"); ``` 2. 初始化Cipher对象:Cipher对象需要被初始化为加密模式或解密模式。可以通过调用init()方法实现。需要传入一个密钥和一个模式参数,如加密模式(Cipher.ENCRYPT_MODE)或解密模式(Cipher.DECRYPT_MODE)。 ```java Key key = new SecretKeySpec(keyBytes, "AES"); cipher.init(Cipher.ENCRYPT_MODE, key); ``` 3. 加密或解密数据:使用已经初始化的Cipher对象,可以使用doFinal()方法来加密或解密数据。需要传入要加密或解密的数据。 ```java byte[] encryptedData = cipher.doFinal(plainText.getBytes()); ``` 完整的加密和解密示例代码如下: ```java import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; import java.security.Key; public class CipherExample { public static void main(String[] args) throws Exception { String plainText = "hello world"; byte[] keyBytes = "0123456789abcdef".getBytes(); // Create cipher object Cipher cipher = Cipher.getInstance("AES"); // Initialize cipher object Key key = new SecretKeySpec(keyBytes, "AES"); cipher.init(Cipher.ENCRYPT_MODE, key); // Encrypt data byte[] encryptedData = cipher.doFinal(plainText.getBytes()); System.out.println("Encrypted data: " + new String(encryptedData)); // Initialize cipher object for decryption cipher.init(Cipher.DECRYPT_MODE, key); // Decrypt data byte[] decryptedData = cipher.doFinal(encryptedData); System.out.println("Decrypted data: " + new String(decryptedData)); } } ``` 上述代码使用AES算法加密和解密数据。注意,密钥的长度必须是16个字节。如果需要使用其他算法或长度的密钥,需要进行相应的修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值