当前位置: 首页 > article >正文

java开发 网络安全 java开发转网络安全

实验内容

1.掌握Socket程序的编写;

2.掌握密码技术的使用;

3.设计安全传输系统。

实验步骤

1. 基于Java Socket实现安全传输

2. 基于TCP实现客户端和服务器,结对编程一人负责客户端,一人负责服务器

3. 使用Git进行版本控制

4. 选择对称算法进行数据加解密.

5. 选择非对称算法对对称加密密钥进行密钥分发.

6. 选择合适的Hash算法进行完整性验证.

7. 选择合适的算法对Hash值进行签名/验证.

发送方使用DES对明文加密,属于对称加密算法,加密速度快但是初始密钥分发不能保证其安全性,使用RSE加密DES的密钥信息,然后再用对称加密,可以解决密钥分发问题,又能保障加密速度。

接收方接到信息后,使用对称解密算法,用RSA解密密钥信息,首先发送端用Hash函数产生足以区别文件的摘要值,再由接收端使用相同的Hash函数自行产生文件摘要,并比对与先前解密结果是否相符。

实验代码

(客户端)

import java.net.*;
 
import java.io.*;
 
import java.security.*;
 
import javax.crypto.*;
 
import javax.crypto.spec.*;
 
import java.security.spec.*;
 
import javax.crypto.interfaces.*;
 
import java.security.interfaces.*;
 
import java.math.*;
public class Client {
 
    public static void main(String srgs[]) throws Exception {
 
       try {
 
           KeyGenerator kg = KeyGenerator.getInstance("DESede");
 
           kg.init(168);
 
           SecretKey k = kg.generateKey();
 
           byte[] ptext2 = k.getEncoded();
 
 
 
           // 创建连接特定服务器的指定端口的Socket对象
 
           Socket socket = new Socket("192.168.80.1", 8028);
 
           // 网络输入流
 
           BufferedReader in = new BufferedReader(new InputStreamReader(
 
                  socket.getInputStream()));
 
           // 网络输出流
 
           PrintWriter out = new PrintWriter(new BufferedWriter(
 
                  new OutputStreamWriter(socket.getOutputStream())), true);
 
           // 创建键盘输入流
 
           BufferedReader stdin = new BufferedReader(new InputStreamReader(
 
                  System.in));
 
 
 
           FileInputStream f3 = new FileInputStream("Skey_RSA_pub.dat");
 
           ObjectInputStream b2 = new ObjectInputStream(f3);
 
           RSAPublicKey pbk = (RSAPublicKey) b2.readObject();
 
           BigInteger e = pbk.getPublicExponent();
 
           BigInteger n = pbk.getModulus();
 
           BigInteger m = new BigInteger(ptext2);
 
           BigInteger c = m.modPow(e, n);
 
           String cs = c.toString();
 
           out.println(cs); // 通过网络传送到服务器
 
 
 
           System.out.print("请输入待发送的数据:");
 
           String s = stdin.readLine();
 
           Cipher cp = Cipher.getInstance("DESede");
 
           cp.init(Cipher.ENCRYPT_MODE, k);
 
           byte ptext[] = s.getBytes("UTF8");
 
           byte ctext[] = cp.doFinal(ptext);
 
           String str = parseByte2HexStr(ctext);
 
           out.println(str);
 
 
 
           String x = s;
 
           MessageDigest m2 = MessageDigest.getInstance("MD5");
 
           m2.update(x.getBytes());
 
           byte a[] = m2.digest();
 
           String result = "";
 
           for (int i = 0; i < a.length; i++) {
 
              result += Integer.toHexString((0x000000ff & a[i]) | 0xffffff00)
 
                     .substring(6);
 
           }
 
           System.out.println(result);
 
           out.println(result);
 
 
 
           str = in.readLine();// 从网络输入流读取结果
 
           System.out.println("从服务器接收到的结果为:" + str); // 输出服务器返回的结果
 
       } catch (Exception e) {
 
           System.out.println(e);
 
       } finally {
 
       }
 
 
 
    }
 
 
 
    public static String parseByte2HexStr(byte buf[]) {
 
       StringBuffer sb = new StringBuffer();
 
       for (int i = 0; i < buf.length; i++) {
 
           String hex = Integer.toHexString(buf[i] & 0xFF);
 
           if (hex.length() == 1) {
 
              hex = '0' + hex;
 
           }
 
           sb.append(hex.toUpperCase());
 
       }
 
       return sb.toString();
 
    }
 
 
 
    public static byte[] parseHexStr2Byte(String hexStr) {
 
       if (hexStr.length() < 1)
 
           return null;
 
       byte[] result = new byte[hexStr.length() / 2];
 
       for (int i = 0; i < hexStr.length() / 2; i++) {
 
           int high = Integer.parseInt(hexStr.substring(i * 2, i * 2 + 1), 16);
 
           int low = Integer.parseInt(hexStr.substring(i * 2 + 1, i * 2 + 2),
 
                  16);
 
           result[i] = (byte) (high * 16 + low);
 
       }
 
       return result;
 
    }
 
}
(服务端)
import java.net.*;
 
import java.io.*;
 
import java.security.*;
 
import java.security.spec.*;
 
import javax.crypto.*;
 
import javax.crypto.spec.*;
 
import javax.crypto.interfaces.*;
 
import java.security.interfaces.*;
 
import java.math.*;
 
 
 
public class Server {
 
    public static void main(String srgs[]) throws Exception {
 
       ServerSocket sc = null;
 
       Socket socket = null;
       
       try {
 
           sc = new ServerSocket(8029);// 创建服务器套接字
 
           System.out.println("端口号:" + sc.getLocalPort());
 
           System.out.println("服务器已经启动...");
 
           socket = sc.accept(); // 等待客户端连接
 
           System.out.println("已经建立连接");
 
           // 获得网络输入流对象的引用
 
           BufferedReader in = new BufferedReader(new InputStreamReader(
 
                  socket.getInputStream()));
 
           // //获得网络输出流对象的引用
 
           PrintWriter out = new PrintWriter(new BufferedWriter(
 
                  new OutputStreamWriter(socket.getOutputStream())), true);
 
 
 
           String aline2 = in.readLine();
 
           BigInteger c = new BigInteger(aline2);
 
           FileInputStream f = new FileInputStream("Skey_RSA_priv.dat");
 
           ObjectInputStream b = new ObjectInputStream(f);
 
           RSAPrivateKey prk = (RSAPrivateKey) b.readObject();
 
           BigInteger d = prk.getPrivateExponent();
 
           BigInteger n = prk.getModulus();
 
           BigInteger m = c.modPow(d, n);
 
           byte[] keykb = m.toByteArray();
 
           String aline = in.readLine();// 读取客户端传送来的数据
 
           byte[] ctext = parseHexStr2Byte(aline);
 
           Key k = new SecretKeySpec(keykb, "DESede");
 
           Cipher cp = Cipher.getInstance("DESede");
 
           cp.init(Cipher.DECRYPT_MODE, k);
 
           byte[] ptext = cp.doFinal(ctext);
 
 
 
           String p = new String(ptext, "UTF8");
 
           System.out.println("从客户端接收到信息为:" + p); // 通过网络输出流返回结果给客户端
 
 
 
           String aline3 = in.readLine();
 
           String x = p;
 
           MessageDigest m2 = MessageDigest.getInstance("MD5");
 
           m2.update(x.getBytes());
 
           byte a[] = m2.digest();
 
           String result = "";
 
           for (int i = 0; i < a.length; i++) {
 
              result += Integer.toHexString((0x000000ff & a[i]) | 0xffffff00)
 
                     .substring(6);
 
           }
 
           System.out.println(result);
 
 
 
           if (aline3.equals(result)) {
 
              System.out.println("匹配成功");
 
           }
 
 
 
           out.println("匹配成功");
 
           out.close();
 
           in.close();
 
           sc.close();
 
       } catch (Exception e) {
 
           System.out.println(e);
 
       }
 
    }
 
 
 
    public static String parseByte2HexStr(byte buf[]) {
 
       StringBuffer sb = new StringBuffer();
 
       for (int i = 0; i < buf.length; i++) {
 
           String hex = Integer.toHexString(buf[i] & 0xFF);
 
           if (hex.length() == 1) {
 
              hex = '0' + hex;
 
           }
 
           sb.append(hex.toUpperCase());
 
       }
 
       return sb.toString();
 
    }
 
 
 
    public static byte[] parseHexStr2Byte(String hexStr) {
 
       if (hexStr.length() < 1)
 
           return null;
 
       byte[] result = new byte[hexStr.length() / 2];
 
       for (int i = 0; i < hexStr.length() / 2; i++) {
 
           int high = Integer.parseInt(hexStr.substring(i * 2, i * 2 + 1), 16);
 
           int low = Integer.parseInt(hexStr.substring(i * 2 + 1, i * 2 + 2),
 
                  16);
 
           result[i] = (byte) (high * 16 + low);
 
       }
 
       return result;
 
    }
 
}

java开发 网络安全 java开发转网络安全_java

java开发 网络安全 java开发转网络安全_java_02

出现的问题及总结

通过ipconfig在命令行中查看IPv4的地址输入Socket中,显示无法连接,通过变化端口再次连接客户端向服务器发送消息,试过几次不同的端口最后显示匹配成功。问题在于如何在用完端口后及时关闭。

在相同的无线网下可以匹配成功并收到客户端的消息,在不同的无线网下IPv4地址不同不能连接。


http://www.kler.cn/a/535815.html

相关文章:

  • 计算机毕业设计hadoop+spark+hive民宿推荐系统 酒店推荐系统 民宿价格预测 酒店价预测 机器学习 深度学习 Python爬虫 HDFS集群
  • Python利用VideoCapture和FFmpeg读取多个rtsp流性能的比较
  • 【React】受控组件和非受控组件
  • Ubuntu 20.04配置网络
  • 腾讯云 TI 平台部署与调用DeepSeek-R1大模型的实战指南
  • 人工智能赋能企业系统架构设计:以ERP与CRM系统为例
  • Deepseek 接入Word处理对话框(隐藏密钥)
  • Servlet笔记(上)
  • 深入解析二分查找算法:原理、实现与变种
  • 深度学习篇---深度学习相关知识点关键名词含义
  • MySQL 缓存机制与架构解析
  • react的antd表单校验,禁止输入空格并触发校验提示
  • 【中间件】 Kafka
  • spring基础总结
  • 【kafka实战】04 Kafka生产者发送消息过程源码剖析
  • 深入浅出 NRM:加速你的 npm 包管理之旅
  • 图论- DFS/BFS遍历
  • Java面试汇总>>>初级工程师—面试1000题
  • CSV数据分析智能工具(基于OpenAI API和streamlit)
  • Netty之JavaNIO编程模型介绍01
  • 基于docker搭建Kafka集群,使用内部自带的Zookeeper方式搭建
  • Java进阶:Zookeeper相关笔记
  • E卷-螺旋数字矩阵-(100分)
  • langchain教程-3.OutputParser/输出解析
  • websocket自动重连封装
  • MyBatis核心配置文件详解:从层级关系到实战配置