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

Posted dky-wzw

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了# 学号 2017-2018-20172309 《程序设计与数据结构》实验五报告相关的知识,希望对你有一定的参考价值。

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

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

1.实验内容

  • 预备实验:
    • 实验要求:

      1.伙伴1编写服务器端程序,接收客户端发送的数据(形式如下:12 15 8 100 25 34 19),将其排序后,发回给客户端。
      2.伙伴2编写客户端程序,将一串字符串(形式如下:12 15 8 100 25 34 19)发送给服务器端,接收排序后的程序,并显示。
      3.截图上传,附上码云地址。

    • 实验结果:技术分享图片
      技术分享图片

    • 程序代码:https://gitee.com/CS-IMIS-23/20172309_javaProgramming/blob/master/Test/test4/SocketServer.java
  • 实验一:
  • 实验二:
    • 实验要求:

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

    • 程序代码:https://gitee.com/CS-IMIS-23/20172309_javaProgramming/commit/05b5f89e5e3ac0849301491c205788ed5127cb5d

  • 实验三:
    • 实验要求:

      1. 注意责任归宿,要会通过测试证明自己没有问题
      2. 基于Java Socket实现客户端/服务器功能,传输方式用TCP
      3. 客户端让用户输入中缀表达式,然后把中缀表达式调用MyBC.java的功能转化为后缀表达式,把后缀表达式用3DES或AES算法加密后通过网络把密文发送给服务器
      4. 服务器接收到后缀表达式表达式后,进行解密(和客户端协商密钥,可以用数组保存),然后调用MyDC.java的功能计算后缀表达式的值,把结果发送给客户端
      5. 客户端显示服务器发送过来的结果
      6. 上传测试结果截图和码云链接
    • 实验结果:技术分享图片
      技术分享图片
    • 程序代码:https://gitee.com/CS-IMIS-23/20172309_javaProgramming/commit/63d4894a9a022b36c18cd2e8a9a12127c30649b5

  • 实验四:
    • 实验要求:

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

  • 实验五:
    • 实验要求:

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

    • 程序代码:https://gitee.com/CS-IMIS-23/20172309_javaProgramming/tree/master/Test/test4/wednesdaytest/test5

      2. 问题及解决方案:

  • 问题一:运行了以后一直没反应,(保证自己写的代码没问题!)技术分享图片

  • 解决方案:这个实验是根据老师发过来的代码进行改造的,因此在这

    > //出现问题 
    >     String info=null;
    >            String temp=null;
    >            while(!((temp = bufferedReader.readLine()) ==null)){//当使用while语句时,因为temp一直是空的,所以循环一直进行!(在前面应该对temp进行赋值,令temp = info)
    >                info = temp;
    >                System.out.println("我是服务器,学号【20172310】用户信息为:" + info);
    >            }
  • 问题二:在进行测试2时,当中缀表达式中含有“×”时,出现乱码!输出结果不能显示“×”。
  • 解决方案:出现这个问题的方法可能是使用的字符标准不同:技术分享图片
    客服端与服务器都得使用“UTF-8”标准。

  • 问题三:进行测试四的时候,需要使用DH算法进行秘钥传输。而生成秘钥的程序需要使用命令行进行实验。

    >public static void main(String args[ ]) throws Exception{//此处只能使用命令行输入命令
    >    DHParameterSpec DHP=
    >new DHParameterSpec(skip1024Modulus,skip1024Base);
    >
    >         KeyPairGenerator kpg= KeyPairGenerator.getInstance("DH");
    >         kpg.initialize(DHP);
    >         KeyPair kp=kpg.genKeyPair();
    >    
    >         PublicKey pbk=kp.getPublic();
    >         PrivateKey prk=kp.getPrivate();
    >         // 保存公钥
    >         FileOutputStream  f1=new FileOutputStream(args[0]);
    >         ObjectOutputStream b1=new  ObjectOutputStream(f1);
    >         b1.writeObject(pbk);
    >         // 保存私钥
    >         FileOutputStream  f2=new FileOutputStream(args[1]);
    >         ObjectOutputStream b2=new  ObjectOutputStream(f2);
    >         b2.writeObject(prk);
    >       }

    而我想要的是在想使用这个程序,调用一个方法就行,因此,我们可以这样改:

    >     public static void fun(String s1,String s2) throws Exception{//将 args[] 改成一个方法+参数 
    >            DHParameterSpec DHP= new DHParameterSpec(skip1024Modulus,skip1024Base);
    >            KeyPairGenerator kpg= KeyPairGenerator.getInstance("DH");
    >            kpg.initialize(DHP);
    >            KeyPair kp=kpg.genKeyPair();
    >            PublicKey pbk=kp.getPublic();
    >            PrivateKey prk=kp.getPrivate();
    >            //保存公钥
    >            FileOutputStream f1=new FileOutputStream(s1);
    >            ObjectOutputStream b1=new  ObjectOutputStream(f1);
    >            b1.writeObject(pbk);
    >            //保存私钥
    >            FileOutputStream  f2=new FileOutputStream(s2);
    >            ObjectOutputStream b2=new  ObjectOutputStream(f2);
    >            b2.writeObject(prk);
    >          }

    这样我们想要实现这个功能,只需要调用这个方法就行了。

    3. 收获感悟


    实验五是在实验三的基础上做的,用到了实验三详细说明的密码学内容。在学实验三的时候,根本看不懂!!!可能是自己没认真看全部是复制粘贴的。不过现在重新学了一下感觉好多了,好像能看出个所以然出来了。实验五的目的是让我们学会用加密形式进行传输,虽然在实验的过程中出现了很多错误,但最后都解决了,而且在做实验的过程中发现弄这个实验其实也挺有趣的。最后提交作业的时候发现自己是交的比较早的,因为我是站在巨人的肩膀上完成实验的(参考了网上的一些方法)!在此感谢他们~

4. 参考文献

1.java密码学算法
2.java IO流总结
3.IO流详解
4.DH算法原理

以上是关于# 学号 2017-2018-20172309 《程序设计与数据结构》实验五报告的主要内容,如果未能解决你的问题,请参考以下文章

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

学号 2017-2018-20172309 《程序设计与数据结构》第4周学习总结

# 学号 2017-2018-20172309 《程序设计与数据结构》第1周学习总结

2017-2018-20172309 『Java程序设计』课程 结对编程练习_四则运算

2017-2018 20172309第六章学习总结

2017-2018-20172309 《程序设计与数据结构》第八周学习总结