zoukankan      html  css  js  c++  java
  • 20172310 2017-2018-2 《程序设计与数据结构》实验五报告

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

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

    实验内容

    任务1:

    两人一组结对编程:
    参考http://www.cnblogs.com/rocedu/p/6766748.html#SECDSA
    结对实现中缀表达式转后缀表达式的功能 MyBC.java
    结对实现从上面功能中获取的表达式中实现后缀表达式求值的功能,调用MyDC.java
    上传测试代码运行结果截图和码云链接

    任务2:

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

    任务3:

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

    任务4:

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

    任务5:

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

    码云链接

    实验过程及结果

    任务1:虽然给出的任务是结对实现中缀表达式转后缀表达式的功能 MyBC.java和实现后缀表达式求值的功能,调用MyDC.java。但是我们继续使用了我们最初版本的四则运算的代码(Android开发的时候有修改过代码)。

    任务2:基于Java Socket实现客户端/服务器功能,传输方式用TCP。

    本来是打算我和队友都尝试一下客户端和服务器,但是貌似我的电脑配置有问题,如果我作为客户端,队友没办法连接上,
    在网上百度了好久,都没能成功,于是接下来的实验都是我作为客户端。

    这时队友的博客链接20172309 实验五报告

    什么是Java Socket 、TCP呢?


    TCP

    tcp/ip协议(transmission control protocol/internet protocol)定义了电子设备如何连入因特网以及数据如何在它们之间传输的标准。
    如今,tcp/ip协议已成为计算机网络协议事实上的标准。在计算机网络体系结构中,网络层为主机之间提供逻辑通信,运输层为应用进程之间提供端到端的逻辑通信。
    而tcp是tcp/ip协议簇的一个面向连接的提供可靠交付服务的运输层协议,这就是说,应用程序在使用tcp协议之前,必须建立tcp连接;在传输数据完毕后,必须释放已经建立的tcp连接。其中,每一条tcp连接只能是点对点的,tcp连接的端点不是主机,不是主机的ip地址,不是应用进程,也不是运输层的协议端口,而是套接字。

    给大家一篇参考:JAVA 通过 Socket 实现 TCP 编程

    结果:

    任务3:把后缀表达式用3DES或AES算法加密后通过网络把密文发送给服务器

    这些都可以在娄老师的博客中进行学习Java 密码学算法

    任务4:客户端和服务器用DH算法进行3DES或AES算法的密钥交换

    DH算法:迪菲-赫尔曼密钥交换(Diffie–Hellman key exchange,简称“D–H”) 是一种安全协议。
    它可以让双方在完全没有对方任何预先信息的条件下通过不安全信道建立起一个密钥。这个密钥可以在后续的通讯中作为对称密钥来加密通讯内容。
    例如:Alice 和Bob想要在一个不安全的信道共享一个密钥,该密钥可被用来进行后续的其他的操作,并且仅被Alice和Bob所知,第三方无法得知。
    一个简单的方法就是,现在全世界都是知道一个值 P=100。Alice生成随机值5,然后乘上P,接着发送Pa = 500给Bob;通样Bob生成随机值6,然后乘上P,接着发送Pb = 600给Alice。
    这样,Alice 有 100,5 ,600,Bob有100,6,500。
    Alice计算: 随机值5(自己私钥) * 600(对端的公钥) = 3000 等式1
    Bob计算 : 随机值6(自己私钥) * 500(对端的公钥) = 3000 等式2
    这样 Alice就和Bob共享了一个值3000,这就是他们共享密钥。

    这是最简单一种情景,DH算法其实我没怎么学懂,只能是学习一下人家的代码。

    任务5:服务器接收到后缀表达式表达式后,进行解密,解密后计算明文的MD5值,和客户端传来的MD5进行比较,

    一致则调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端

    这个实验就是来看看信息的完整性(Integrity):主要确保数据只能由授权方或以授权的方式进行修改,即数据在传输过程中不能被未授权方修改。

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

    • 问题1:链接队友电脑时出现“错误:java.net.SocketException: Connection reset”
    • 问题1解决方案:
      1、网络编程时未正确捕获java.net.SocketException, 客户端先关闭就会报这个异常;(检查发送数据是否符合服务器接收格式,不然的话服务器会自动断开连接,这样,socket就会被关闭,那么你就不能使用IO流读取数据,这样就会报这个错误)
      2、数据库和应用服务器的网段不同
      3、好像说防火墙的比较多

    不过这些方法最终都没能解决连接不上我的电脑的问题╮(─▽─)╭。

    • 问题2:在传输密钥时是要将byte[]转换成Object,错误信息为:
      java.io.StreamCorruptedException: invalid stream header(无效的流头):
    • 问题2解决方案:bytes在反序列化为Object的前提是byte[]是通过ObjectOutputStream序列化的,否则直接将一个任意的byte[]转换成Object时会报错。

    转化方法
    1.Byte[] to Object:
    (byte b[])
    ObjectInputStream ois = new ObjectInputStream (new ByteArrayInputStream (b));
    Object o = ois.readObject();
    2.Object to Byte[]:
    (Object obj)
    byte b[] = null;
    ByteArrayInputStream bais = new ByteArrayInputStream();
    ObjectOutputStream oos = new ObjectOutputStream(bais);
    oos.writeObject(obj);

    其他(感悟、思考等)

    其实这次的实验代码完全靠自己想是有难度的,很多最基本的密码学知识我还没有怎么弄懂。不过还是蛮开心的,这个学期的实验课到了尾声,自己终于完成了一次次的实验,有点小自豪[]( ̄▽ ̄)*

    参考资料

  • 相关阅读:
    Java重命名文件
    三星Samsung 4.4.2该负责人制度,简化名单
    hdu 1203 I NEED A OFFER!
    springMVC整合JAXB
    主流芯片解决方案Ambarella的高清网络摄像机、德州仪器和控制海思
    Objective-C路成魔【18-复制对象】
    QStyleFactory类参考
    QT QSqlQuery QSqlQueryModel
    linux mysql 卸载后重装
    更改Mysql数据库存储位置的具体步骤
  • 原文地址:https://www.cnblogs.com/Qiuxia2017/p/9192552.html
Copyright © 2011-2022 走看看