代码改变世界

实验五 Java网络编程及安全

2015-10-25 23:13  20159213-杨凤  阅读(195)  评论(0编辑  收藏  举报

   北京电子科技学院

实      验      报      告

课程:移动平台应用开发实践  班级: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的功能和用法,不断的调试代使两台计算机实现单向通信,虽然代码不是自己写的但能实现通也是让人很兴奋,极大的激发了求知的欲望。本次实验没有解决的问题是,每次客户端和服务端连接之后,再次连接就会出现问题,还的进行更换端口,这种通信即浪费时间又浪费精力。下面是出现的问题

 

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

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