java通信加密_基于客户端通信的RSA加密java源码实现

本文介绍了如何使用Java实现基于RSA的客户端加密通信。通过创建ServerSocket和Socket,结合RSAUtil类生成和交换公钥,实现数据的安全传输。示例代码展示了如何设置端口、IP地址,以及使用JFrame进行UI展示。
摘要由CSDN通过智能技术生成

import java.awt.EventQueue;

import javax.swing.JFrame;

import javax.swing.JPanel;

import javax.swing.border.EmptyBorder;

import javax.swing.JLabel;

import java.awt.Font;

import javax.swing.JOptionPane;

import javax.swing.JScrollPane;

import javax.swing.JTextArea;

import javax.swing.JTextPane;

import javax.swing.JButton;

import java.awt.event.ActionListener;

import java.awt.event.ActionEvent;

import java.io.DataInputStream;

import java.io.DataOutputStream;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.ObjectInputStream;

import java.io.ObjectOutputStream;

import java.math.BigInteger;

import java.net.ServerSocket;

import java.net.Socket;

import java.net.UnknownHostException;

import java.security.PublicKey;

import java.security.interfaces.RSAPublicKey;

public class Client extends JFrame implements Runnable{

private static final long serialVersionUID =

6555473007391854674L;

private JPanel contentPane;

private JTextArea publicKeyArea;//显示公钥面板

private JTextArea

resultArea;//显示接收到的明文以及转换后的密文

private JTextPane port;//接受本机的端口设置

private JTextPane ipArea;//输入目标IP的面板

private JTextPane portArea;//输入目标机的端口号

private JTextPane messageArea;//输入要发送的明文区域

private int portNum;//设置的客户端端口号

private ServerSocket ss=null;

private

Socket socket=null;

private

Thread thread=null;//该线程打开特定的端口号等待连接

private

String sendToip;//要接收方的ip地址

private int sendToport;//要接受方的端口号

private

RSAUtil rsa=null;

private String ee;

private String nn;//公钥参数

private static PublicKey pk;

public static void main(String[] args) {

EventQueue.invokeLater(new

Runnable() {

public void

run() {

try

{

Client

frame = new Client();

frame.setVisible(true);

}

catch (Exception e) {

e.printStackTrace();

}

}

});

}

public Client() {

setTitle("RSA\u52A0\u5BC6\u7B97\u6CD5");

setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

setBounds(100, 100, 694,

502);

contentPane = new

JPanel();

contentPane.setBorder(new

EmptyBorder(5, 5, 5, 5));

setContentPane(contentPane);

contentPane.setLayout(null);

JLabel lblNewLabel = new

JLabel("\u516C\u94A5\u53C2\u6570");

lblNewLabel.setFont(new

Font("宋体", Font.PLAIN, 16));

lblNewLabel.setBounds(50, 58,

69, 30);

contentPane.add(lblNewLabel);

JScrollPane scrollPane = new

JScrollPane();

scrollPane.setBounds(159, 28,

464, 86);

contentPane.add(scrollPane);

publicKeyArea = new

JTextArea();

publicKeyArea.setEditable(false);

publicKeyArea.setFont(new

Font("Monospaced", Font.PLAIN, 18));

publicKeyArea.setLineWrap(true);

scrollPane.setViewportView(publicKeyArea);

JScrollPane scrollPane_1 = new

JScrollPane();

scrollPane_1.setBounds(50, 148,

574, 120);

contentPane.add(scrollPane_1);

resultArea = new

JTextArea();

resultArea.setEditable(false);

resultArea.setFont(new

Font("Monospaced", Font.PLAIN, 18));

resultArea.setLineWrap(true);

scrollPane_1.setViewportView(resultArea);

JLabel lblNewLabel_1 = new

JLabel("\u5BA2\u6237\u7AEF\u7AEF\u53E3");

lblNewLabel_1.setFont(new

Font("宋体", Font.PLAIN, 16));

lblNewLabel_1.setBounds(159,

301, 86, 30);

contentPane.add(lblNewLabel_1);

port = new JTextPane();

port.setFont(new Font("宋体",

Font.PLAIN, 18));

port.setBounds(271, 301, 80,

30);

contentPane.add(port);

JButton btnNewButton = new

JButton("\u8BBE\u7F6E");

btnNewButton.addActionListener(new

ActionListener() {

//设置按钮消息事件

public void

actionPerformed(ActionEvent e) {

portNum=Integer.parseInt(port.getText());

thread.start();

}

});

btnNewButton.setFont(new

Font("宋体", Font.PLAIN, 16));

btnNewButton.setBounds(397,

298, 86, 36);

contentPane.add(btnNewButton);

JLabel lblip = new

JLabel("\u53D1\u9001\u65B9IP");

lblip.setFont(new Font("宋体",

Font.PLAIN, 16));

lblip.setBounds(50, 357, 69,

30);

contentPane.add(lblip);

JLabel label_1 = new

JLabel("\u53D1\u9001\u65B9\u7AEF\u53E3");

label_1.setFont(new Font("宋体",

Font.PLAIN, 16));

label_1.setBounds(310, 357, 86,

30);

contentPane.add(label_1);

ipArea = new JTextPane();

ipArea.setFont(new Font("宋体",

Font.PLAIN, 18));

ipArea.setBounds(129, 357, 154,

30);

contentPane.add(ipArea);

thread=new Thread(this);

try {

rsa=new

RSAUtil();

rsa.generateKey();

} catch (Exception e1) {

// TODO

Auto-generated catch block

e1.printStackTrace();

}

JButton button = new

JButton("\u8FDE\u63A5");

button.addActionListener(new

ActionListener() {

//连接按钮消息事件

public void

actionPerformed(ActionEvent e) {

sendToip=ipArea.getText();//目的IP

sendToport=Integer.parseInt(portArea.getText());//目的端口号

try

{

socket=new

Socket(sendToip,sendToport);

JOptionPane.showMessageDialog(null,

"connect success!");

ObjectInputStream

ois=new ObjectInputStream(socket.getInputStream());

try

{

pk = (PublicKey)ois.readObject();

FileOutputStream

f1=new FileOutputStream("Skey_RSA_pub.dat");

ObjectOutputStream b1=new ObjectOutputStream(f1);

b1.writeObject(pk);

先运行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控制台交互,仅仅为演示原理及简单效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值