Java试验四
北京电子科技学院(BESTI)
实 验 报 告
课程: Java 班级:1352 姓名:朱国庆 学号:20135237
成绩: 指导教师:娄嘉鹏 实验日期:2015.6.11
实验密级: 预习程度: 实验时间:15:30~18:00
仪器组次:37 必修/选修:选修 实验序号:(四)
实验名称:Java面向对象程序设计
实验目的:
1.掌握Java网络编程的方法;
2.掌握Java安全编程的方法;
3. 能综合使用各种技术;
实验内容一:
1.运行教材上TCP代码,结对进行,一人服务器,一人客户端。
2.利用加解密代码包,编译运行代码,客户端加密,服务器解密。
3.客户端加密明文后将密文通过TCP发送。
4.加密使用DES,DES加密密钥key发送至服务器,使用服务器的公钥加密,公钥算法使用RSA,检验发送信息的完整性使用MD5。
结对网络编程
服务器:
客户端:

实验代码:
服务器:
// file name:ComputeTCPServer.java
import java.net.*;
import java.io.*;
import java.security.*;
import java.security.spec.*;
import javax.crypto.*;
import javax.crypto.spec.*;
import javax.crypto.interfaces.*;
import java.security.interfaces.*;
import java.math.*;
public class ComputeTCPServer{
        public static void main(String srgs[]) throws Exception {
        ServerSocket sc = null;
        Socket socket=null;
            try {
			sc= new ServerSocket(4410);//创建服务器套接字
            System.out.println("端口号:" + sc.getLocalPort());
            System.out.println("服务器已经启动...");
            socket = sc.accept();   //等待客户端连接
            System.out.println("已经建立连接");
                //获得网络输入流对象的引用
            BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
                ////获得网络输出流对象的引用
			PrintWriter out=new PrintWriter(new BufferedWriter(new OutputStreamWriter(socket.getOutputStream())),true);
String aline2=in.readLine();
			BigInteger c=new BigInteger(aline2);
			FileInputStream f=new FileInputStream("Skey_RSA_priv.dat");
			ObjectInputStream b=new ObjectInputStream(f);
			RSAPrivateKey prk=(RSAPrivateKey)b.readObject( );
			BigInteger d=prk.getPrivateExponent();
			BigInteger n=prk.getModulus();
			//System.out.println("d= "+d);
			//System.out.println("n= "+n);
			BigInteger m=c.modPow(d,n);
			//System.out.println("m= "+m);
			byte[] keykb=m.toByteArray();
			//String aline3=new String(mt,"UTF8");
			//String aline3=parseByte2HexStr(byte buf[]);
String aline=in.readLine();//读取客户端传送来的数据
			//FileInputStream  f2=new FileInputStream("keykb1.dat");
			//int num2=f2.available();
			//byte[] keykb=new byte[num2];          
			//f2.read(keykb);
			byte[] ctext=parseHexStr2Byte(aline);
			Key k=new  SecretKeySpec(keykb,"DESede");
			Cipher cp=Cipher.getInstance("DESede");
			cp.init(Cipher.DECRYPT_MODE, k);
			byte []ptext=cp.doFinal(ctext);
String p=new String(ptext,"UTF8");
			System.out.println("从客户端接收到信息为:"+p); //通过网络输出流返回结果给客户端
/*String aline2=in.readLine();
			BigInteger c=new BigInteger(aline2);
			FileInputStream f=new FileInputStream("Skey_RSA_priv.dat");
			ObjectInputStream b=new ObjectInputStream(f);
			RSAPrivateKey prk=(RSAPrivateKey)b.readObject( );
			BigInteger d=prk.getPrivateExponent();
			BigInteger n=prk.getModulus();
			//System.out.println("d= "+d);
			//System.out.println("n= "+n);
			BigInteger m=c.modPow(d,n);
			//System.out.println("m= "+m);
			byte[] mt=m.toByteArray();
			//String aline3=new String(mt,"UTF8");*/
String aline3=in.readLine();
		String x=p;
		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);
if(aline3.equals(result)){
			System.out.println("匹配成功");
		}
out.println("匹配成功");
			out.close();
			in.close();
			sc.close();
            } catch (Exception e) {
            System.out.println(e);
        } 
    }
	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;  
    }  
}
客户端:
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 ComputeTCPClient {
    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();
			//String kstr=parseByte2HexStr(kb);
//创建连接特定服务器的指定端口的Socket对象
			Socket socket = new Socket("10.1.0.243", 4410);
            //获得从服务器端来的网络输入流
            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();
			//System.out.println("e= "+e);
			//System.out.println("n= "+n);
			//byte ptext2[]=kstr.getBytes("UTF8");
			BigInteger m=new BigInteger(ptext2);
			BigInteger c=m.modPow(e,n);
			//System.out.println("c= "+c);
			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);
/*s=result;
			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();
			//System.out.println("e= "+e);
			//System.out.println("n= "+n);
			byte ptext2[]=s.getBytes("UTF8");
			BigInteger m=new BigInteger(ptext2);
			BigInteger c=m.modPow(e,n);
			//System.out.println("c= "+c);
			String cs=c.toString( );
            out.println(cs);  //通过网络传送到服务器*/
str=in.readLine();//从网络输入流读取结果
            System.out.println( "从服务器接收到的结果为:"+str); //输出服务器返回的结果
		}
        catch (Exception e) {
            System.out.println(e);
        }
		finally{
			//stdin.close();
			//in.close();
			//out.close();
			//socket.close();			
		}
}
	 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;  
    }  
}
统计的PSP(Personal Software Process)时间:
| 
 步骤  | 
 耗时(min)  | 
 百分比  | 
| 
 需求分析  | 
 30  | 
 12.5%  | 
| 
 设计  | 
 70  | 
 29.2%  | 
| 
 代码实现  | 
 70  | 
 29.2%  | 
| 
 测试  | 
 40  | 
 16.7%  | 
| 
 分析总结  | 
 30  | 
 12.5%  | 
实验中遇到的问题:
对本次试验还是不太会,通过大量请教同学,和自己查找网上总有所获吧。在客户端和服务器设置时需要端口一致。
小组成员:
吕松鸿:http://www.cnblogs.com/lv-20135229/p/4553600.html
黄伟业:http://www.cnblogs.com/1551127024hwy/
Java试验四的更多相关文章
- Java的四种内部类
		
Java的四种内部类包括如下: 成员内部类 静态内部类 局部内部类 匿名内部类 成员内部类: 定义在另一个类(外部类)的内部,而且与成员方法和属性平级叫成员内部类,......相当于外部类的非静态方法 ...
 - Java实验四
		
20145113 Java实验四 快捷键 之前没怎么记ISDEA的快捷键,但是熟练使用快捷键可以带来很多的便利,于是先开始学习一些常用的快捷键,就采用它默认的快捷键,这样后期就不会出现冲突,一些and ...
 - Java中四种引用:强、软、弱、虚引用
		
这篇文章非常棒:http://alinazh.blog.51cto.com/5459270/1276173 Java中四种引用:强.软.弱.虚引用 1.1.强引用当我们使用new 这个关键字创建对象时 ...
 - java中四种引用类型
		
java中四种引用类型 今天看代码,里面有一个类java.lang.ref.SoftReference把小弟弄神了,试想一下,接触java已经有3年了哇,连lang包下面的类都不了解,怎么混.后来在 ...
 - 《Thinking In Java第四版》拾遗
		
<Thinking In Java第四版>拾遗 转自我的github(http://katsurakkkk.github.io/2016/05/Thinking-In-Java%E7%AC ...
 - Java第四次上课博文动手动脑
		
Java第四次上课博文动手动脑 1. 查看String.equals()方法 public class StringEquals { /** * @param args the command ...
 - Java进阶(四十七)Socket通信
		
Java进阶(四十七)Socket通信 今天讲解一个 Hello Word 级别的 Java Socket 通信的例子.具体通讯过程如下: 先启动Server端,进入一个死循环以便一直监听某端口是 ...
 - Java进阶(四十三)线程与进程的区别
		
Java进阶(四十三)线程与进程的区别 1.线程的基本概念 概念:线程是进程中执行运算的最小单位,是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点在运行中必 ...
 - Java进阶(四十二)Java中多线程使用匿名内部类的方式进行创建3种方式
		
Java中多线程使用匿名内部类的方式进行创建3种方式 package cn.edu.ujn.demo; // 匿名内部类的格式: public class ThreadDemo { public st ...
 
随机推荐
- 【原型图】Mockplus
			
Mockplus 原型设计工具
 - C++ - 模板(template)中typename的使用方法
			
声明template参数时, 前缀关键字class和typename可以互换; 使用关键字typename标识嵌套从属类型名称, 但不需在基类列表和成员初始化列表内使用. 从属名称(dependent ...
 - mysql索引和外键
			
innodb外键: 1.CASCADE:从父表删除或更新会自动删除或更新子表中匹配的行 2.SET NULL:从父表删除或更新行,会设置子表中的外键列为NULL,但必须保证子表列没有指定NOT NUL ...
 - 洛谷 P4430 小猴打架
			
洛谷 P4430 小猴打架 题目描述 一开始森林里面有N只互不相识的小猴子,它们经常打架,但打架的双方都必须不是好朋友.每次打完架后,打架的双方以及它们的好朋友就会互相认识,成为好朋友.经过N-1次打 ...
 - codevs 2639 约会计划
			
codevs 2639 约会计划 题目描述 Description cc是个超级帅哥,口才又好,rp极高(这句话似乎降rp),又非常的幽默,所以很多mm都跟他关系不错.然而,最关键的是,cc能够很好的 ...
 - 10-[CSS]-盒模型:border,padding,margin
			
1.CSS盒子模型 HTML文档中的每个元素都被描绘成矩形盒子,这些矩形盒子通过一个模型来描述其占用空间,这个模型称为盒子模型. 盒子模型通过四个边界来描述:margin(外边距),border(边框 ...
 - CF 348 D. Turtles
			
D. Turtles 链接 题意: 给定一个N*M的棋盘,有些格子不能走,问有多少种从(1,1)到(N,M)的两条不相交路径. 分析: lGV定理. 定理:点集A={a1,a2,…an}A={a1,a ...
 - 用 Python 带你看《我不是药神》
			
我们都是小人物,我们都得了同一种病,我们都穷.——<我不是药神> 我不是程序员 我就是想求求你们,别动不动就拿篇10W+的文章来吓唬人好吗?说点有用的东西好吗?我们需要精神粮食不需要腐蚀精 ...
 - C# 通用树形数据结构
			
前言 树在图论中是一种重要的图,由于其自身的许多特殊性质,也是一种重要的计算机数据结构,在很多地方都有用.但是这些树大多都是作为其他应用的内部数据结构来使用.我们无法了解这些树的详细信息,而 .Net ...
 - CSS清浮动办法
			
骨灰级解决办法: .clear{clear:both;height:0;overflow:hidden;} 上诉办法是在需要清除浮动的地方加个div.clear或者br.clear,我们知道这样能解决 ...