20172332 2017-2018-2 《程序设计与数据结构》实验五报告

20172332 2017-2018-2 《程序设计与数据结构》实验五报告

课程:《程序设计与数据结构》
班级: 1723
姓名: 于欣月
学号:20172332
实验教师:王志强
实验日期:2018年6月13日
必修/选修: 必修

1.实验内容

  • ①结对实现中缀表达式转后缀表达式的功能 MyBC.java
    结对实现从上面功能中获取的表达式中实现后缀表达式求值的功能,调用MyDC.java
    上传测试代码运行结果截图和码云链接

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

  • ③加密结对编程:1人负责客户端,一人负责服务器
    注意责任归宿,要会通过测试证明自己没有问题
    基于Java Socket实现客户端/服务器功能,传输方式用TCP
    客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式用3DES或AES算法加密后通过网络把密文发送给服务器
    服务器接收到后缀表达式表达式后,进行解密(和客户端协商密钥,可以用数组保存),然后调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
    客户端显示服务器发送过来的结果
    上传测试结果截图和码云链接

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

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

2. 实验过程及结果

前期准备:

  • 1.查找到自己的IP地址,为进行服务器和客户端之间的连接做准备。(Windows:先用win+R打开,输入cmd,再输入IPconfig查找IP地址)

  • 2.搭建服务器和客户端,并成功连接。

过程:

因为我们是三人一组,所以客户端和服务器都有相应的代码。
一.作为客户端。

  • 1.(1)

    • MyDC的代码就是四则运算中Cal类的代码,具体码云中有。
  • 2.(2)

    • 20172313输入中缀转后缀,20172332接受后缀并计算结果返回给20172313
  • 3.(3)

    • 20172332给20172313传加密后的后缀,20172313解密后计算结果并返回给20172332
  • 4.(4)

    • 20172332给20172313传,20172313给20172332传结果
  • 5.(5)

二.作为服务器。

  • 1.(1)

    • 第一个实验不需要服务器和客户端。
  • 2.(2)

    • 第二个实验只需要把write的内容改为需要返回的结果。
  • 3.(3)

  • 4.(4)

  • 5.(5)

3. 实验过程中遇到的问题和解决过程

  • 问题1:DH算法到底是什么。

  • 问题1解决方案:有A,B两个也就是分别为客户端和服务器。然后A和B分别生成各自的私钥和公钥,把公钥向对方传去。自己的私钥和别人的公钥生成共享密钥。并且这个共享密钥和对方生成的一样。所以对方直接解密就可以。

  • 问题2:Invalid AES key length: 128 bytes?

  • 问题2解决方案:只能读24位,所以需要截取(0,24)

  • 问题3:服务器与客户端连接不上。

  • 问题3解决方案:①先检查防火墙是否关闭。若没关闭,请关闭防火墙。②再检查IP地址和端口。IP地址在不同的网络中IP地址是不同的。端口若被占用需要改变端口。

其他(感悟、思考等)

  • 这次的实验深入了自己对于密码学的了解,更加体会到了加密、解密的过程。只不过因为如今知识积累的问题,并不能明白一些算法的原理,相信在后续的学习过程中会让自己了解。
  • 关于实验中的一些问题,百度中很少能查到解决方案,但是通过询问同学就能解决,更加体现了团队合作能力。

参考资料

posted @ 2018-06-19 20:32  雲深不知处  阅读(178)  评论(0编辑  收藏  举报