您的位置:首页 > 理论基础 > 计算机网络

利用java编写网络通信程序

2007-10-27 08:05 309 查看
2001年08月19日 18:57:00

利用java编写网络通信程序

作者:于洪斌、马俊光、车雪松
  一、java与网络通信
  java是一门适合于分布式计算环境、尤其是Internet程序设计的语言。这不仅仅在于java具有很好的安全性和可移植性,还在于java为Internet编程提供了丰富的网络类库支持。利用这些网络类库,可以轻松编写多种类型的网络通信程序。



  TCP/IP协议是当今最流行的协议,也是Internet的基础协议,它代表的是一个协议集合。除传输控制协议TCP和网际协议IP外,TCP/IP协议集还包括其他一些协议,如UDP、FTP、UUCP、ICMP等。
  一般的TCP/IP网络数据通信主要可分为两种不同的通信协议,一种是面向连接的通信协议,这种传输方式在数据传送前必须先在两端建立连接,并且所传送的数据不会丢失,这种方式称为TCP,也称为Stream;另一种方式则是面向非连接方式,即传送数据前,并不必先建立连接,而是将所要传送的数据包成一个分组再传送,使用这种方式,由于没有额外的控制,所以传送的数据可能丢掉。这种方式称为UDP,也称为Datagram。



  TCP和UDP都是传输层上的通信协议,也是一般TCP/IP网络上最常使用的通信协议,且各有其用途,如TCP较可靠,所以用在不允许数据丢失的应用上。而UDP则较多应用于处理速度要求较快、数据传输可靠性要求不是很高的应用上,如数据广播。在java中也支持这两种不同的协议,对它们的支持是以类库的形式提供的。通过Socket和ServerSocket类提供了对TCP通信的支持,对于UDP通信则提供了DatagramSocket和DatagramPacket类。它们都包含在java.net类库中。本文中,我们主要探讨TCP通信程序的写法,而UDP通信程序的写法与此类似。



   二、通信程序的编写
  在进一步讨论之前,我们先来看看Socket和ServerSocket类的定义(表1)和(表2),关于这两个类的详细内容请见sun公司的JDK或microsoft公司VJ++ 1.1的联机文档。
  
  要使用上面所提供的功能编写网络通信程序,我们可以将要通信的两端分成服务器和客户机端,即建立所谓的客户机/服务器编程模式。在服务器端必须先建立一个ServerSocket对象,然后等待客户机端的访问。而在客户机端,则是建立一个Socket对象直接跟服务器端连接,如果连接建立成功,则服务器端便会产生一个Socket对象,然后我们就可以利用这个Socket对象跟客户机端的Socket对象沟通了。此时在服务器和客户机之间建立了一条可靠连接,客户机和服务器可以在这条连接上可靠的传送数据。客户机发出请求,服务器监听来自客户机的请求,并为客户机提供相应的服务。



  基于上述原理,我们编写了简单的客户机/服务器模式的网络通信程序。在服务器端,服务器监听客户机的请求,为每个客户机请求建立Socket连接,从而为客户机提供服务。而所提供的服务只是读取来自客户机的一行文本,并把它发回给客户机。以下是服务器端的通信程序。
  import java.io.*;
  import java.net.*;
  class javaserver extends Thread {
   ServerSocket server;
   public javaserver() {
   try {
   server = new ServerSocket(600);
   }
   catch(IOException e) {
   System.out.println("Cannot create Server");
   System.exit(0);
   }
   System.out.println("Now socket server will Start");
   this.start();
   }
   public void run() {
   try {
   while (true) {
   Socket client = server.accept();
   service ss = new service(client);
   }
   }
   catch(IOException e) {
   System.out.println("cannot provide service !");
   System.exit(1);
   }
   }
   public static void main(String args[]){
   String data;
   DataInputStream KeyInput;
   new javaserver();
   KeyInput = new DataInputStream(System.in);
   try {
   data = KeyInput.readLine();
   }
   catch (IOException e){
   return;
   }
   if (data.equals("quit")) System.exit(1);
   }
  }
   class service extends Thread {
   String data;
   DataInputStream InputS;
   PrintStream OutputS;
   Socket Client;
   public service(Socket ClientSocket) {
   Client = ClientSocket;
   try {
   InputS = new DataInputStream
   (Client.getInputStream());
   OutputS = new PrintStream
   (Client.getOutputStream());
   }
   catch (IOException e){
   System.out.println("Cannot Connect with Client !");
   return;
   }
   this.start();
   }
   public void run(){
   try {
   while (true){
   data = InputS.readLine();
   if (data == null) break;
   else {
   OutputS.println(data);
   System.out.println("From Client: " + data);
   }
   }
   }
   catch (IOException e){
   System.out.println("Read Data error");
   }
   try {
   Client.close();
   }
   catch (IOException e){
   System.out.println("Cannot close socket");
   }
   }
  }
   在上面的程序中,我们使用了多线程机制。javaserver和service对象本身都是一个线程。javaserver对象首先创建一个ServerSocket对象,并启动线程的运行。它的run()方法用于监听来自客户机的连接。每当有一个新的客户机连接时,ServerSocket就会创建一个新的Socket类实例,并创建一个service对象,同时启动这个对象的线程。每个service对象用于完成与客户机通信、提供服务的任务。这样服务器可以同时与多个客户机连接,同时为多个客户机提供服务。当从标准输入中接收到quit字符串时,服务器退出运行。
  在客户机端,首先创建一个Socket对象,用于与服务器通信。它从标准输入中读取数据,把这些数据传给服务器,再从服务器读取应答信息,然后把这些应答信息写到标准输出。当读取了5行的数据后,客户机程序将退出运行。以下是客户机端的通信程序。
  import java.io.*;
  import java.net.*;
  class javaclient {
   public static void main(String args[]){
   String data;
   Socket Client;
   DataInputStream InputS;
   DataInputStream KeyS;
   PrintStream OutputS;
   int i = 0;
   try {
   Client = new Socket("172.17.3.2",600);
   InputS = new
   DataInputStream(Client.getInputStream());
   OutputS = new PrintStream
   (Client.getOutputStream());
   KeyS = new DataInputStream(System.in);
   }
   catch(IOException e){
   System.out.println("Cannot Connect
   with Server");
   return;
   }
   try {
   while (i>5){
   data = KeyS.readLine();
   OutputS.println(data);
   System.out.println("ECHO From
   Server:"+ InputS.readLine());
   i++;
   }
   }
   catch(IOException e) {
   System.out.println("IOException
   Happened");
   }
   try{
   System.out.println("Now will
   end this program");
   Client.close();
   }
   catch(IOException e){
   System.out.println("system cannot
   close socket");
   }
   }
  }
   三、结束语
  通过以上的讨论可知,用java语言编写网络通信程序非常简单,这主要是因为java语言本身就是一门面向网络编程的语言。java提供了多个可用于访问标准Internet协议的类库,从而支持多种Internet协议,包括:FTP,HTTP,NNTP和WWW等,这极大的简化了网络程序设计,可以比较方便的编写出功能完善的应用程序。
  以上只是我们对java语言进行网络通信程序设计的粗浅讨论。利用java语言进行程序设计的好处不一而论,愿我们能起到抛砖引玉的作用。
  联系地址:哈尔滨工程大学六系95级研究生
  邮政编码:150001
  联系电话:(0451)2519605

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=3510
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: