zoukankan      html  css  js  c++  java
  • 实验五 Java网络编程及安全

       北京电子科技学院

    实      验      报      告

    课程:移动平台应用开发实践  班级:201592  姓名:杨凤  学号:20159213

    成绩:___________  指导老师:娄嘉鹏   实验日期 :2015.10.25

    实验名称:                          Java 网络编程及安全                                         

    实验内容:      1、掌握 Socket程序的编写    2、掌握密码技术的使用    3、设计安全传输系统   

     

    我的实验搭档是孙楠    http://www.cnblogs.com/20159214sn/,客户端由我负责,她负责服务端

    实验步骤:

    1、基于Java Socket实现安全传输

    2、给予TCP实现客户端和服务器,结对编程一人负责客户端一人负责服务器

    3、使用Git进行版本控制

    4、选择对称算法进行数据加密

    5、选择非对称算法对对称加密密钥进行密钥分发

    6、选择和蛇的Hash算法进行完整性验证。

     在本次试验中我组用DES加密和RSA解密。

    客户端

    import java.net.*;

    import java.io.*;

    import java.security.*;

    import javax.crypto.*;

    import javax.crypto.spec.*;

    import java.security.spec.*;

    import javax.crypto.interfaces.*;

    import java.security.interfaces.*;

    import java.math.*;

    public class Client {

        public static void main(String srgs[]) throws Exception {

           try {

               KeyGenerator kg = KeyGenerator.getInstance("DESede");

               kg.init(168);

               SecretKey k = kg.generateKey();

               byte[] ptext2 = k.getEncoded();

               // 创建连接特定服务器的指定端口的Socket对象

               Socket socket = new Socket("192.168.80.1", 8028);

               // 网络输入流

               BufferedReader in = new BufferedReader(new InputStreamReader(

                      socket.getInputStream()));

               // 网络输出流

               PrintWriter out = new PrintWriter(new BufferedWriter(

                      new OutputStreamWriter(socket.getOutputStream())), true);

               // 创建键盘输入

               BufferedReader stdin = new BufferedReader(new InputStreamReader(

                      System.in));

               FileInputStream f3 = new FileInputStream("Skey_RSA_pub.dat");

               ObjectInputStream b2 = new ObjectInputStream(f3);

               RSAPublicKey pbk = (RSAPublicKey) b2.readObject();

               BigInteger e = pbk.getPublicExponent();

               BigInteger n = pbk.getModulus();

               BigInteger m = new BigInteger(ptext2);

               BigInteger c = m.modPow(e, n);

               String cs = c.toString();

               out.println(cs); // 通过网络传送到服务器

               System.out.print("请输入待发送的数据:");

               String s = stdin.readLine();

               Cipher cp = Cipher.getInstance("DESede");

               cp.init(Cipher.ENCRYPT_MODE, k);

               byte ptext[] = s.getBytes("UTF8");

               byte ctext[] = cp.doFinal(ptext);

               String str = parseByte2HexStr(ctext);

               out.println(str);

               String x = s;

               MessageDigest m2 = MessageDigest.getInstance("MD5");

               m2.update(x.getBytes());

               byte a[] = m2.digest();

               String result = "";

               for (int i = 0; i < a.length; i++) {

                  result += Integer.toHexString((0x000000ff & a[i]) | 0xffffff00)

                         .substring(6);

               }

               System.out.println(result)

               out.println(result);

               str = in.readLine();// 从网络输入流读取结

               System.out.println("从服务器接收到的结果为:" + str); // 输出服务器返回的结果

           } catch (Exception e) {

               System.out.println(e);

           } finally {

           }

        }

        public static String parseByte2HexStr(byte buf[]) {

           StringBuffer sb = new StringBuffer();

           for (int i = 0; i < buf.length; i++) {

               String hex = Integer.toHexString(buf[i] & 0xFF);

               if (hex.length() == 1) {

                  hex = '0' + hex;

               }

               sb.append(hex.toUpperCase());

           }

           return sb.toString();

        }

        public static byte[] parseHexStr2Byte(String hexStr) {

           if (hexStr.length() < 1)

               return null;

           byte[] result = new byte[hexStr.length() / 2];

           for (int i = 0; i < hexStr.length() / 2; i++) {

               int high = Integer.parseInt(hexStr.substring(i * 2, i * 2 + 1), 16);

               int low = Integer.parseInt(hexStr.substring(i * 2 + 1, i * 2 + 2),

                      16);

               result[i] = (byte) (high * 16 + low);

           }

           return result;

        }

    }

     两台机器实现的通信

     

     

    实验总结

    在本次试验中,大致了解了Socket的功能和用法,不断的调试代使两台计算机实现单向通信,虽然代码不是自己写的但能实现通也是让人很兴奋,极大的激发了求知的欲望。本次实验没有解决的问题是,每次客户端和服务端连接之后,再次连接就会出现问题,还的进行更换端口,这种通信即浪费时间又浪费精力。下面是出现的问题

     

    经过百度查询,让关闭运行端但也没有解决问题。

    另一个问题是两台电脑必须在同一个网段才能连接成功。

     

  • 相关阅读:
    CSP-S 2020 游记
    USACO Mowing the Lawn
    洛谷 P1725 琪露诺
    浅谈单调队列
    浅谈单调栈
    洛谷 P1440 求m区间内的最小值
    POJ 2823 Sliding Window
    洛谷 P1901 发射站
    POJ 2796 Feel Good
    POJ 2559 Largest Rectangle in a Histogram
  • 原文地址:https://www.cnblogs.com/20159213yf/p/4909977.html
Copyright © 2011-2022 走看看