20145206《Java程序设计》实验五Java网络编程及安全

20145206《Java程序设计》实验五 Java网络编程及安全

实验内容

1.掌握Socket程序的编写;

2.掌握密码技术的使用;

3.设计安全传输系统。

实验步骤

我和20145105姜丽结对编程,我设计客户端的部分。

姜丽的博客园主页:http://www.cnblogs.com/schwarizard/

<1>首先建立一个Socket对象,用来连接特定服务器的指定端口,输入的参数是ip地址和端口,注意ip地址是服务器的ip地址,即运行服务器的那台主机的ip地址。

怎么查看主机的ip地址呢?在命令行中输入ipconfig即可。在我的计算机上执行如下:

20145206《Java程序设计》实验五Java网络编程及安全

<2>然后用BufferedReader对象获得从服务器传来的网络输入流,用PrintWriter对象获得从客户端向服务器输出数据的网络输出流,用BufferedReader对象创建键盘输入流,以便客户端从键盘上输入信息。以上根据TCP的客户端代码编写。

<3>下一步是先用RSA算法加密DES的秘钥,加密采用服务器的公钥。将加密后的秘钥传送给服务器。

<4>然后用DES算法加密明文,将密文传到服务器。

<5>然后计算明文的Hash函数值,传送给服务器。

  以上用到的加密算法、秘钥、Hash函数计算过程均利用的老师提供的代码。

<6>最后从网络输入流读取结果,把从服务端返回的结果输出出来。

·代码写好后,先运行服务器,再运行客户端,显示“服务器已经启动后”启动客户端,,连接成功会显示“已经建立连接”,然后就可以从客户端输入数据发送到服务器了。

我的客户端显示结果为:

20145206《Java程序设计》实验五Java网络编程及安全

产生的问题及解决办法:

问题1:出现系统找不到指定文件的问题

解决办法:将Skey_RSA_pub.dat、Skey_RSA_priv.dat拷贝至与src同级的文件夹内

20145206《Java程序设计》实验五Java网络编程及安全

问题2:把Skey_RSA_priv.dat、Skey_RSA_pub.dat拷贝至与src同级的文件夹内之后,发现还是会出现如图所示的问题:

20145206《Java程序设计》实验五Java网络编程及安全

解决办法:在程序调用这个文件前加上指定路径:

C:\\Users\\Administrator\\IdeaProjects\\untitled8\\src\\Skey_RSA_pub.dat

这样问题就解决了!

问题3:会出现连接超时的情况。

解决办法:我们之前连的是服务器的手机热点,后来改用360wi-fi,并且IP地址输入正确,问题就解决啦!

客户端实验代码如下:

package Client;
// file name��ComputeTCPClient.java
import java.net.*;
import java.io.*;
public class ComputeTCPClient {
public static void main(String srgs[]) {
try {
Socket socket = new Socket("172.20.10.5", 4000);
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));
System.out.print("请输入待发送的数据:");
String str=stdin.readLine();
Enc_RSA encode = new Enc_RSA(str);
String s=encode.encodedata; out.println(s);
str=in.readLine();
System.out.println( "从服务器接收到的结果为:"+str);
}
catch (Exception e) {
System.out.println(e);
}
finally{
//stdin.close();
//in.close();
//out.close();
//socket.close();
}
}
} package Client;
import java.io.*;
import java.math.BigInteger;
import java.security.interfaces.RSAPublicKey; public class Enc_RSA {
public String encodedata="";
public Enc_RSA(String s) throws Exception{
FileInputStream f=new FileInputStream("C:\\Users\\Administrator\\IdeaProjects\\untitled8\\src\\Skey_RSA_pub.dat");
ObjectInputStream b=new ObjectInputStream(f);
RSAPublicKey pbk=(RSAPublicKey)b.readObject( );
BigInteger e=pbk.getPublicExponent();
BigInteger n=pbk.getModulus();
byte ptext[]=s.getBytes("UTF8");
BigInteger m=new BigInteger(ptext);
BigInteger c=m.modPow(e,n);
String cs=c.toString( );
encodedata=cs;
}
}

实验心得体会

本次实验主要练习如何把不同的代码放入到一个程序中实现功能,代码部分老师已经给出,关键在于拼凑代码以及对于代码的理解,通过这一周对于“网络编程安全”这篇博客的学习以及同学之间的讨论,大概了解了代码内容,希望可以通过实践掌握、运用。

PSP时间

步骤 耗时 百分比
需求分析 20min 16.7%
设计 40min 33.3%
代码实现 20min 16.7%
测试 20min 16.7%
分析总结 20min 16.7%
上一篇:基于 Axis2的webService接口的基本开发步骤


下一篇:python 数据可视化 -- 真实数据的噪声平滑处理