zoukankan      html  css  js  c++  java
  • 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地址是不同的。端口若被占用需要改变端口。

    其他(感悟、思考等)

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

    参考资料

  • 相关阅读:
    java做微信支付notify_url异步通知服务端的写法
    QT如何编译出带调试信息的qtwebkit库
    Vmware 占用宿主机硬盘空间只增不减
    vmware linux无法正常上网
    Linux中find常见用法示例
    计算机网络OSI参考模型与tcp/ip四层模型
    Core开发-后台任务利器Hangfire使用
    Azure构建PredictionIO和Spark的推荐引擎服务
    NET MVC+EF6+Bootstrap
    服务器
  • 原文地址:https://www.cnblogs.com/yu757503836/p/9199724.html
Copyright © 2011-2022 走看看