20135227黄晓妍实验四

北京电子科技学院(BESTI)

                     实     验    报     告

      课程:Java   班级: 1352     姓名:黄晓妍    学号:20135227

      成绩:               指导教师:娄嘉鹏        实验日期:2015.6.9

      实验密级:           预习程度:              实验时间:15:30~18:00

      仪器组次:27         必修/选修:选修        实验序号:04

      实验名称: 网络编程与安全

      实验目的与要求:

           1.掌握Java网络编程的方法;

         2.掌握Java安全编程的方法;

         3.能综合使用各种技术。

      实验仪器:


名称


型号


数量


计算机


2

     

      统计的PSP(Personal Software Process)时间


步骤


耗时(min)


百分比


需求分析


10


10%


设计


20


20%


代码实现


40


40%


测试


10


10%


分析总结


20


20%

一、    实验内容与步骤

实验内容:

1       编写网络通信程序(基于TCP)

2       对通信内容使用对称加密算法进行加密

3       使用非对称算法分发对称加密中使用的密钥

4       对通信内容进行摘要计算并验证

5       其他安全措施

代码:

package net;

import java.math.*;

import java.net.*;

import java.io.*;

public class ComputeTCPClient {

public static void main(String srgs[]) {

try {

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

Socket socket = new Socket("10.0.6.143", 4421);

//获得从服务器端来的网络输入流

BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));

//获得从客户端向服务器端输出数据的网络输出W流

PrintWriter out = new PrintWriter(new BufferedWriter(new OutputStreamWriter(socket.getOutputStream())), true);

//创建键盘输入流,以便客户端从键盘上输入信息eredWriter(new OutputStreamWriter(socket.getOutputStream())), true);

//创建键盘输入流

BufferedReader stdin = new BufferedReader(new InputStreamReader(System.in));

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

String s = stdin.readLine(); //从键盘读入待发送的数据

String cs = new SEnc().enc(s);

System.out.println("发送到服务器的密文为:" + cs);

//            String t=Read.read();

String ck = new Enc_RSA().Enc();

System.out.println("发送到服务器的加密秘钥为:" + ck);

String result = DigestCalc.hash(s);

out.println(ck);

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

out.println(result);

} catch (Exception e) {

System.out.println(e);

} finally {

//stdin.close();

//in.close();

//out.close();

//socket.close();

}

}

}

package net;

import java.net.*;

import java.io.*;

public class ComputeTCPServer {

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

ServerSocket sc = null;

Socket socket = null;

try {

sc = new ServerSocket(4421);//创建服务器套接字

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 key = in.readLine();

System.out.println("从客户端收到的加密秘钥为:" + key);

byte[] keykb = new Dec_RSA().Dec(key);

String ctext = in.readLine();//读取客户端传送来的数据

System.out.println("从客户端收到的密文为:" + ctext);

String result=SDec.des(ctext, keykb);

String ha = in.readLine();

String sa = DigestCalc.hash(result);

boolean q = Compare.compare(sa, ha);

System.out.println("程序是否完整:" + q);

out.close();

in.close();

sc.close();

} catch (Exception e) {

System.out.println(e);

}

}

}

客户端:

服务端:

二、实验中遇到的问题及其解决方法

1.发送经过DES加密后的密文时采用的是将其转化为字符串的方式,在这里客户端采用的是toString()函数,服务器采用的是getBytes()函数,传输后的密文出现错误。对其问题进行探讨并上网查证,经DES加密后的密文不能使用上述两个函数进行传输,使用网上的一个Change类,问题得以解决,代码如下:

package net;

public class Change {

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;

}

}

2、在两机互联的过程中,无法进行连接,后了解到代码中的端口和IP地址的设置有问题,将IP地址设置为本机之后,同时进行网络连接,两机实现互联。

三、实验体会

本次实验极大的扩展了我们的视野,使我了解到编写程序不仅仅是一个电脑单机操作的事情,也可以上升到网络层次,引起了我对JAVA极大的兴趣。在实验中,我明白怎样创建客户端和服务器,同时利用out.println()和in.readline()函数使其进行数据连接和传输。实验中最大的难点是怎样对数据进行加密,然后进行传输。对老师所给代码进行调用,起初不知道从何做起,后经过大家共同努力,问题得以解决。本次实验对同学们有很大的挑战,同时我们也有相当大的进步。

时间: 2024-10-19 23:46:01

20135227黄晓妍实验四的相关文章

信息安全系统设计基础实验四—20135214万子惠20135227黄晓妍

北京电子科技学院(BESTI) 实     验    报     告 课程:信息安全设计系统基础                        班级:1352 姓名:万子惠 黄晓妍 学号:20135214 20135227 成绩:             指导教师:娄嘉鹏    实验日期:2015.11.16 实验密级:         预习程度:      实验时间:15:30~18:00 仪器组次: 01       必修/选修:必修       实验序号:四 实验名称:外设驱动程序设计 实

信息安全系统设计基础实验五—20135214万子惠20135227黄晓妍

北京电子科技学院(BESTI) 实验报告 课程:信息安全系统设计基础               班级:1352 姓名:黄晓妍 万子惠 学号:20135227 20135214 成绩:指导教师:娄佳鹏           实验日期:2015.11.24 实验密级:预习程度: 实验时间:15:30~18:00 仪器组次:必修/选修:       必修     实验序号:五 实验名称:简单嵌入式WEB 服务器实验 实验目的与要求: 掌握在 ARM 开发板实现一个简单WEB 服务器的过程. 学习在 A

信息安全系统设计基础实验三—20135227黄晓妍 20135214万子惠

北京电子科技学院(BESTI) 实     验    报     告 课程:信息安全设计系统基础           班级:   1352 姓名:黄晓妍 万子惠 学号:20135227 20135214 成绩:             指导教师:娄佳鹏    实验日期:2015.11.24 实验密级:         预习程度:        实验时间:15:30~18:00 仪器组次:          必修/选修:必修     实验序号:03 实验名称:    实时系统的移植 实验目的与要求

信息安全系统设计基础期末总结—20135227黄晓妍

期末总结 每周读书笔记 第二周:http://www.cnblogs.com/angelahxy/p/4818978.html 第三周:http://www.cnblogs.com/angelahxy/p/4839577.html 第四周:http://www.cnblogs.com/angelahxy/p/4852328.html 第五周:http://www.cnblogs.com/angelahxy/p/4869061.html 第六周:http://www.cnblogs.com/ang

信息安全系统设计基础第三周学习总结—20135227黄晓妍

一.Vim编辑器 1.Vim的六种模式 2.Vim三种常用模式的使用方式,以及三者的切换.打开Vim即默认进入普通模式,按i进入插入模式,按esc从插入模式退出普通模式,再按:进入命令行模式. 普通模式下游标的移动 按键 说明 h 左 l 右(小写L) j 下 k 上 w 移动到下一个单词 b 移动到上一个单词 普通模式进入插入模式的方式 命令         说明 i        在当前光标处进行编辑 I        在行首插入 A       在行末插入 a       在光标后插入编辑

信息安全系统设计基础第五周学习总结—20135227黄晓妍

X86 寻址方式经历三代: 1 DOS时代的平坦模式,不区分用户空间和内核空间,很不安全 2 8086的分段模式 3 IA32的带保护模式的平坦模式 ISA 指令集体系结构,机器级程序的指令和格式.它定义了处理状态,指令的格式,以及每条指令对状态的影响. 获得汇编代码的两种方式: gcc -S xxx.c -o xxx.s 获得汇编代码,也可以用objdump -d xxx 反汇编 (反汇编不需要访问程序的源代码或者汇编代码) C语言数据类型在IA32中的大小: P111页表格. 8个寄存器(3

Linux基础入门学习笔记20135227黄晓妍

学习计时:共24小时 读书:1小时 代码:8小时 作业:3小时 博客:12小时 一.学习目标 1. 能够独立安装Linux操作系统 2. 能够熟练使用Linux系统的基本命令 3. 熟练使用Linux中用户管理命令/系统相关命令/文件目录相关命令/打包压缩相关命令/比较合并相关命令/网络相关命令等 4. 熟练应用“搜索”进行举一反三的学习 二.学习资源 1. 课程资料:https://www.shiyanlou.com/courses/413   实验一,课程邀请码:W7FQKW4Y 2. Li

信息安全系统设计基础第十一周学习总结—20135227黄晓妍

第8章异常控制流 控制流:控制转移序列. 控制转移:从一条指令到下一条指令. 异常控制流:现代操作系统通过使控制流发生突变来对系统状态做出反应,这些突变称为异常控制流. 一.异常 1.异常的剖析,如下图所示: 异常:控制流中的突变,用来响应处理器状态的某些变化. Icurr:当前指令 事件:状态变化 2.异常处理 异常表:当处理器检测到有事件发生时,它会通过跳转表,进行一个间接过程调用(异常),到异常处理程序. 异常号:系统中可能的某种类型的异常都分配了一个唯一的非负整数的异常号.异常号是到异常

linux及安全第三周总结——20135227黄晓妍

总结部分: Linux内核源代码: Arch 支持不同cpu的源代码:主要关注x86 Init   内核启动的相关代码:主要关注main.c,整个Linux内核启动代码start_kernel函数 Kernel 核心代码 installing the kernel source:如何安装内核源代码 构建Linux系统os 使用gdb跟踪内核运行过程 -S cpu在初始化之前将其冻结 -s 在tcp端口创建server 分析start_kernel函数 Trap init 涉及中断 这个函数用来做