# 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.截图上传,附上码云地址。

    • 实验结果:1333063-20180619161542948-154469285.png
      1333063-20180619161246012-1069812060.png

    • 程序代码: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. 上传测试结果截图和码云链接
    • 实验结果:1333063-20180619162146901-370912373.png
      1333063-20180619162155557-1525264155.png

    • 程序代码: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. 上传测试结果截图和码云链接
    • 实验结果:1333063-20180619161912496-1310494086.png
      1333063-20180619161923429-261210096.png
    • 程序代码: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. 上传测试结果截图和码云链接
    • 实验结果:1333063-20180619162343992-1576302957.png
      1333063-20180619162354562-1728036990.png
    • 程序代码: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. 上传测试结果截图和码云链接
    • 实验结果:1333063-20180619162457763-1753184756.png
      1333063-20180619162508688-164028151.png

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

      2. 问题及解决方案:

  • 问题一:运行了以后一直没反应,(保证自己写的代码没问题!)1333063-20180619194327289-1997445182.png

  • 解决方案:这个实验是根据老师发过来的代码进行改造的,因此在这
> //出现问题 
>     String info=null;
>            String temp=null;
>            while(!((temp = bufferedReader.readLine()) ==null)){//当使用while语句时,因为temp一直是空的,所以循环一直进行!(在前面应该对temp进行赋值,令temp = info)
>                info = temp;
>                System.out.println("我是服务器,学号【20172310】用户信息为:" + info);
>            }
  • 问题二:在进行测试2时,当中缀表达式中含有“×”时,出现乱码!输出结果不能显示“×”。
  • 解决方案:出现这个问题的方法可能是使用的字符标准不同:1333063-20180619195707183-1326325053.png
    客服端与服务器都得使用“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算法原理

转载于:https://www.cnblogs.com/dky-wzw/p/9192296.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值