2018-2019-2 20175227张雪莹《Java程序设计》
实验五 《网络编程与安全》
实验报告封面
- 课程:Java程序设计 班级:1752班 姓名:张雪莹 学号:20175227
- 指导教师:娄嘉鹏 实验日期:2019年5月25日
- 实验时间:--- 实验序号:实验五
- 实验名称:网络编程与安全
- 实验题目:
- 实验要求:
- 完成云班课中的检查点,也可以先完成实验报告,直接提交。注意不能只有截图,要有知识点,原理,遇到的问题和解决过程等说明。实验报告中一个检查点要有多张截图。
- 发表实验报告博客,标题“学期(如2018-2019-2) 学号(如20175300)实验五 Java网络编程 实验报告”
实验步骤
![1593762-20190525201032997-145350677.jpg](https://i-blog.csdnimg.cn/blog_migrate/2f70298a9dd2b775aa51306680cab83e.jpeg)
- 任务二
- 要求:结对编程:1人负责客户端,一人负责服务器
- 注意责任归宿,要会通过测试证明自己没有问题
- 基于Java Socket实现客户端/服务器功能,传输方式用TCP
- 客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式通过网络发送给服务器
- 服务器接收到后缀表达式,调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
- 客户端显示服务器发送过来的结果
- 上传测试结果截图和码云链接
- 知识点
- 套接字是基于TCP协议的网络通信
- 客户端套接字
- 对象建立方法:使用Socket类
- Socket构造方法:
Socket(String host,int port)
- ServerSocket对象与服务器端套接字
- 构造方法:ServerSocket(int port)
- 使用方法accept()将客户端的套接字和服务器端的套接字连接起来
- 套接字通信基本原则
- 服务器应当启动一个专门的线程,在该线程中和客户的套接字建立连接
- 由于套接字的输入流在读取信息时可能发生阻塞,客户端和服务器端都需要在一个单独的线程中读取信息
- 代码
5-2 - 运行示例
![1593762-20190526134256419-709500252.jpg](https://i-blog.csdnimg.cn/blog_migrate/2238b02c6535a1eeea96c54da34ef63b.jpeg)
![1593762-20190526134304643-1426230591.jpg](https://i-blog.csdnimg.cn/blog_migrate/a48a3ffee55f0a924fc9cc4eec5c3851.jpeg)
- 任务三
- 要求:加密结对编程:1人负责客户端,一人负责服务器
- 注意责任归宿,要会通过测试证明自己没有问题
- 基于Java Socket实现客户端/服务器功能,传输方式用TCP
- 客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式用3DES或AES算法加密后通过网络把密文发送给服务器
- 服务器接收到后缀表达式表达式后,进行解密(和客户端协商密钥,可以用数组保存),然后调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
- 客户端显示服务器发送过来的结果
- 上传测试结果截图和码云链接
- 知识点
- DES算法是目前最常用的对称加密算法
- 实现DES加密主要有以下几个步骤:
- 对称密钥的生成和保存;
- 使用对称密钥进行加密和解密;
- 从文件中获取加密时使用的密钥,使用密钥进行解密。
- 代码
5-3 - 运行示例
![1593762-20190526134629245-1785125260.jpg](https://i-blog.csdnimg.cn/blog_migrate/749b73d19f9a68d43c891dc72dfeb07a.jpeg)
![1593762-20190526134635239-265550535.jpg](https://i-blog.csdnimg.cn/blog_migrate/d633f75ea35c09dae440df88ce35c629.jpeg)
- 任务四
- 要求:密钥分发结对编程:1人负责客户端,一人负责服务器
- 注意责任归宿,要会通过测试证明自己没有问题
- 基于Java Socket实现客户端/服务器功能,传输方式用TCP
- 客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式用3DES或AES算法加密通过网络把密文发送给服务器
- 客户端和服务器用DH算法进行3DES或AES算法的密钥交换
- 服务器接收到后缀表达式表达式后,进行解密,然后调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
- 客户端显示服务器发送过来的结果
- 上传测试结果截图和码云链接
- 知识点
- 使用密钥协定创建共享密钥——DH算法
- DH算法是建立在DH公钥和私钥的基础上的
- 实现DH算法主要有以下几个步骤:
- 代码
5-4 - 运行示例
![1593762-20190527084339466-1154721209.jpg](https://i-blog.csdnimg.cn/blog_migrate/c498578d1d07d14ec5dc1524964e01c1.jpeg)
![1593762-20190527084346897-630012207.jpg](https://i-blog.csdnimg.cn/blog_migrate/66f5f18c79e92d29b95ba240299591a2.jpeg)
- 任务五
- 要求:完整性校验结对编程:1人负责客户端,一人负责服务器
- 注意责任归宿,要会通过测试证明自己没有问题
- 基于Java Socket实现客户端/服务器功能,传输方式用TCP
- 客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式用3DES或AES算法加密通过网络把密文和明文的MD5値发送给服务器
- 客户端和服务器用DH算法进行3DES或AES算法的密钥交换
- 服务器接收到后缀表达式表达式后,进行解密,解密后计算明文的MD5值,和客户端传来的MD5进行比较,一致则调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
- 客户端显示服务器发送过来的结果
- 上传测试结果截图和码云链接
- 知识点
- Java摘要算法- MD5
java.security
包中的MessageDigest类提供了计算消息摘要的方法
- 生成MessageDigest对象:
MessageDigest m=MessageDigest.getInstance("MD5");
- 传入需要计算的字符串:
m.update(x.getBytes("UTF8" ));
(x为需要计算的字符串,update传入的参数是字节类型或字节类型数组,对于字符串,需要先使用getBytes( )方法生成字符串数组。)
- 计算消息摘要:
byte s[ ]=m.digest( );
(执行MessageDigest对象的digest( )方法完成计算,计算的结果通过字节类型的数组返回。)
- 代码
5-5 - 运行示例
![1593762-20190527095000069-360246276.jpg](https://i-blog.csdnimg.cn/blog_migrate/691f60fcca8d79ac38d12580748643ce.jpeg)
![1593762-20190527095008204-1547924639.jpg](https://i-blog.csdnimg.cn/blog_migrate/4f8734707f62bc7ea7d8324801116100.jpeg)
结对伙伴及其博客链接
20175212
转载于:https://www.cnblogs.com/zxy20175227/p/10923041.html