网络编程与安全

实验五 网络编程与安全

实验准备

)

活动一 两人一组结对编程:

0. 参考http://www.cnblogs.com/rocedu/p/6766748.html#SECDSA 

 
1. 结对实现中缀表达式转后缀表达式的功能 MyBC.java
2. 结对实现从上面功能中获取的表达式中实现后缀表达式求值的功能,调用MyDC.java
3. 上传测试代码运行结果截图和码云链接
  • 活动一主要和前两周的结对编程相似

  • 结果

活动二 结对编程:1人负责客户端,一人负责服务器

0. 注意责任归宿,要会通过测试证明自己没有问题
1. 基于Java Socket实现客户端/服务器功能,传输方式用TCP
2. 客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式通过网络发送给服务器
3. 服务器接收到后缀表达式,调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
4. 客户端显示服务器发送过来的结果
5. 上传测试结果截图和码云链接

)

![](http://images2015.cnblogs.com/blog/1062696/201706/1062696-20170611131237668-1058764431.png

)

  • 结果

活动三 加密结对编程:1人负责客户端,一人负责服务器

0. 注意责任归宿,要会通过测试证明自己没有问题
1. 基于Java Socket实现客户端/服务器功能,传输方式用TCP
2. 客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式用3DES或AES算法加密后通过网络把密文发送给服务器
3. 服务器接收到后缀表达式表达式后,进行解密(和客户端协商密钥,可以用数组保存),然后调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
4. 客户端显示服务器发送过来的结果
5. 上传测试结果截图和码云链接
  • 过程
    在实验二的基础上,学习娄老师的对称算法与非对称算法,此处用的是对称算法对中缀表达式进行加密。通过创建3DES算法的对象,生成密钥并在Client.java中加密,在Server.java中接受密文并解密;

    [参考](http://blog.csdn.net/hwaphon/article/details/52190653

)

  • 结果

活动四 密钥分发结对编程:1人负责客户端,一人负责服务器

0. 注意责任归宿,要会通过测试证明自己没有问题
1. 基于Java Socket实现客户端/服务器功能,传输方式用TCP
2. 客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式用3DES或AES算法加密通过网络把密文发送给服务器
3. 客户端和服务器用DH算法进行3DES或AES算法的密钥交换
4. 服务器接收到后缀表达式表达式后,进行解密,然后调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
5. 客户端显示服务器发送过来的结果
6. 上传测试结果截图和码云链接
  • 过程

任务四的目的就是通过非对称算法对客户端传输到服务器的中缀表达式进行加密,防止中缀表达式在传输过程中被人恶意进行篡改,毁坏。而它通过Diffie-Hellman方法得以实现,Diffie-Hellman方法可以确保共享KEY安全穿越不安全网络的方法。

  • 结果

活动五 完整性校验结对编程:1人负责客户端,一人负责服务器

0. 注意责任归宿,要会通过测试证明自己没有问题
1. 基于Java Socket实现客户端/服务器功能,传输方式用TCP
2. 客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式用3DES或AES算法加密通过网络把密文和明文的MD5値发送给服务器
3. 客户端和服务器用DH算法进行3DES或AES算法的密钥交换
4. 服务器接收到后缀表达式表达式后,进行解密,解密后计算明文的MD5值,和客户端传来的MD5进行比较,一致则调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
5. 客户端显示服务器发送过来的结果
  • 结果

参考内容

原文地址:https://www.cnblogs.com/1zhjch/p/6986379.html