自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Java在Client/Server中應(yīng)用

開(kāi)發(fā) 后端
和Internet上的許多環(huán)境一樣,完整的Java應(yīng)用環(huán)境實(shí)際上也是一個(gè)客戶機(jī)/服務(wù)器環(huán)境,更確切地說(shuō)是瀏覽器/服務(wù)器模型。本文將為你詳述Java在Client/Server中的應(yīng)用,希望對(duì)你能有所幫助。

   JavaClient/Server中應(yīng)用

  一. Java網(wǎng)絡(luò)應(yīng)用模型

  和Internet上的許多環(huán)境一樣,完整的Java應(yīng)用環(huán)境實(shí)際上也是一個(gè)客戶機(jī)/服務(wù)器環(huán)境,更確切地說(shuō)是瀏覽器/服務(wù)器模型(即Browser/Server模型,簡(jiǎn)稱Web模型)。但與傳統(tǒng)的客戶機(jī)/服務(wù)器(C/S) 的二層結(jié)構(gòu)不同,應(yīng)用Java的Web模型是由三層結(jié)構(gòu)組成的。傳統(tǒng)的C/S結(jié)構(gòu)通過(guò)消息傳遞機(jī)制,由客戶端發(fā)出請(qǐng)求給服務(wù)器,服務(wù)器進(jìn)行相應(yīng)處理后經(jīng)傳遞機(jī)制送回客戶端。而在Web模型中,服務(wù)器一端被分解成兩部分:一部分是應(yīng)用服務(wù)器(Web 服務(wù)器),另一部分是數(shù)據(jù)庫(kù)服務(wù)器。

  針對(duì)分布式計(jì)算環(huán)境,Java通過(guò)其網(wǎng)絡(luò)類庫(kù)提供了良好的支持。對(duì)數(shù)據(jù)分布,Java提供了一個(gè)URL(Uniform Resource Locator) 對(duì)象, 利用此對(duì)象可打開(kāi)并訪問(wèn)網(wǎng)絡(luò)上的對(duì)象,其訪問(wèn)方式與訪問(wèn)本地文件系統(tǒng)幾乎完全相同。對(duì)操作分布,Java的客戶機(jī)/ 服務(wù)器模式可以把運(yùn)算從服務(wù)器分散到客戶一端(服務(wù)器負(fù)責(zé)提供查詢結(jié)果,客戶機(jī)負(fù)責(zé)組織結(jié)果的顯示),從而提高整個(gè)系統(tǒng)的執(zhí)行效率,增加動(dòng)態(tài)可擴(kuò)充性。Java網(wǎng)絡(luò)類庫(kù)是Java 語(yǔ)言為適應(yīng)Internet 環(huán)境而進(jìn)行的擴(kuò)展。另外,為適應(yīng)Internet的不斷發(fā)展,Java還提供了動(dòng)態(tài)擴(kuò)充協(xié)議,以不斷擴(kuò)充Java網(wǎng)絡(luò)類庫(kù)。

  Java的網(wǎng)絡(luò)類庫(kù)支持多種Internet協(xié)議,包括Telnet, FTP 和HTTP (WWW),與此相對(duì)應(yīng)的Java網(wǎng)絡(luò)類庫(kù)的子類庫(kù)為:

  Java.net

  Java.net.ftp

  Java.net.www.content

  Java.net.www.html

  Java.net.www.http

  這些子類庫(kù)各自容納了可用于處理Internet協(xié)議的類和方法。其中,java.net用于處理一些基本的網(wǎng)絡(luò)功能,包括遠(yuǎn)程登錄(Telnet);java.net.ftp用于處理ftp協(xié)議;java.net.www.content用于處理WWW 頁(yè)面內(nèi)容;java.net.www.html 和java.net.www.http 則分別提供了對(duì)HTML 語(yǔ)言和HTTP 協(xié)議的支持。

  二. 客戶機(jī)/服務(wù)器環(huán)境下的Java應(yīng)用程序

  客戶機(jī)/服務(wù)器在分布處理過(guò)程中,使用基于連接的網(wǎng)絡(luò)通信模式。該通信模式首先在客戶機(jī)和服務(wù)器之間定義一套通信協(xié)議,并創(chuàng)建一Socket類,利用這個(gè)類建立一條可靠的鏈接;然后,客戶機(jī)/服務(wù)器再在這條鏈接上可靠地傳輸數(shù)據(jù)??蛻魴C(jī)發(fā)出請(qǐng)求,服務(wù)器監(jiān)聽(tīng)來(lái)自客戶機(jī)的請(qǐng)求,并為客戶機(jī)提供響應(yīng)服務(wù)。這就是典型的"請(qǐng)求-- 應(yīng)答" 模式。下面是客戶機(jī)/服務(wù)器的一個(gè)典型運(yùn)作過(guò)程:

  1、服務(wù)器監(jiān)聽(tīng)相應(yīng)端口的輸入;

  2、客戶機(jī)發(fā)出一個(gè)請(qǐng)求;

  3、服務(wù)器接收到此請(qǐng)求;

  4、服務(wù)器處理這個(gè)請(qǐng)求,并把結(jié)果返回給客戶機(jī);

  5、重復(fù)上述過(guò)程,直至完成一次會(huì)話過(guò)程。

  按照以上過(guò)程,我們使用Java語(yǔ)言編寫一個(gè)分別針對(duì)服務(wù)器和客戶機(jī)的應(yīng)用程序(Application)。該程序在服務(wù)器上時(shí),程序負(fù)責(zé)監(jiān)聽(tīng)客戶機(jī)請(qǐng)求,為每個(gè)客戶機(jī)請(qǐng)求建立Socket 連接,從而為客戶機(jī)提供服務(wù)。本程序提供的服務(wù)為:讀取來(lái)自客戶機(jī)的一行文本,反轉(zhuǎn)該文本,并把它發(fā)回給客戶機(jī)。

  通過(guò)該程序?qū)嵗覀兛吹?,使用Java語(yǔ)言設(shè)計(jì)C/S程序時(shí)需要注意以下幾點(diǎn):

  (1) 服務(wù)器應(yīng)使用ServerSocket 類來(lái)處理客戶機(jī)的連接請(qǐng)求。當(dāng)客戶機(jī)連接到服務(wù)器所監(jiān)聽(tīng)的端口時(shí),ServerSocket將分配一新的Socket 對(duì)象。這個(gè)新的Socket 對(duì)象將連接到一些新端口,負(fù)責(zé)處理與之相對(duì)應(yīng)客戶機(jī)的通信。然后,服務(wù)器繼續(xù)監(jiān)聽(tīng)ServerSocket,處理新的客戶機(jī)連接。

  Socket 和ServerSocket 是Java網(wǎng)絡(luò)類庫(kù)提供的兩個(gè)類。

  (2) 服務(wù)器使用了多線程機(jī)制。Server對(duì)象本身就是一個(gè)線程,它的run()方法是一個(gè)無(wú)限循環(huán),用以監(jiān)聽(tīng)來(lái)自客戶機(jī)的連接。每當(dāng)有一個(gè)新的客戶機(jī)連接時(shí),ServerSocket就會(huì)創(chuàng)建一個(gè)新的Socket類實(shí)例,同時(shí)服務(wù)器也將創(chuàng)建一新線程,即一個(gè)Connection 對(duì)象,以處理基于Socket 的通信。與客戶機(jī)的所有通信均由這個(gè)Connection 對(duì)象處理。Connection的構(gòu)造函數(shù)將初始化基于Socket 對(duì)象的通信流,并啟動(dòng)線程的運(yùn)行。與客戶機(jī) 的通信以及服務(wù)的提供,均由Connection對(duì)象處理。

  (3) 客戶機(jī)首先創(chuàng)建一Socket對(duì)象,用以與服務(wù)器通信。之后需創(chuàng)建兩個(gè)對(duì)象:DataInputStream 和PrintStream,前者用以從Socket 的InputStream 輸入流中讀取數(shù)據(jù),后者則用于往Socket的OutputStream 中寫數(shù)據(jù)。***,客戶機(jī)程序從標(biāo)準(zhǔn)輸入(如:控制臺(tái))中讀取數(shù)據(jù),并把這些數(shù)據(jù)寫到服務(wù)器,在從服務(wù)器讀取應(yīng)答消息,然后把這些應(yīng)答消息寫到準(zhǔn)輸出。

  以下分別為服務(wù)器和客戶機(jī)端的源程序清單。本程序在NT 4.0 網(wǎng)絡(luò)環(huán)境(TCP/IP)下使用JDK1.1 調(diào)試通過(guò)。

#p#

  三. 編寫服務(wù)器類Java程序

  1. // Server.java  
  2.     import java.io.*;  
  3.     import java.net.*;  
  4.     public class Server extends Thread  
  5.     {  
  6.     public final static int Default_Port=6543;  
  7.     protectd int port;  
  8.     protectd ServerSockt listen_socket;  
  9.     // 定義出錯(cuò)例程:如果出現(xiàn)異常錯(cuò)誤,退出程序。  
  10.     Public static void fail(Exception e, String msg)  
  11.     {  
  12.     System.err.println(msg + ": " + e);  
  13.     System.exit(1);  
  14.     }  
  15.     // 定義并啟動(dòng)服務(wù)器的Socket 例程,監(jiān)聽(tīng)客戶機(jī)的連接請(qǐng)求。  
  16.     public Server(int port)  
  17.     {  
  18.     if(port == 0) port = Default_Port;  
  19.     this.port = port;  
  20.     try 
  21.     {  
  22.     listen_socket = new ServerSocket(port);  
  23.     }  
  24.     catch(IOException e) fail(e, "Exception creating server socket");  
  25.     System.out.println("Server: listening on port" + port);  
  26.     This.start();  
  27.     }  
  28. /* 下面為服務(wù)器監(jiān)聽(tīng)線程的主程序。該線程一直循環(huán)執(zhí)行,監(jiān)聽(tīng)并接受客戶機(jī)發(fā)出的連接請(qǐng)求。對(duì)每一個(gè)連接,均產(chǎn)生一個(gè)連接對(duì)象與之對(duì)應(yīng),通過(guò)Socket 通道進(jìn)行通信。*/ 
  29.     public void run()  
  30.     {  
  31.     try 
  32.     {  
  33.     while(true)  
  34.     {  
  35.     Socket client_socket = listen_socket.accept();  
  36.     Connection c = new Connection(client_socket);  
  37.     }  
  38.     }  
  39.     catch(IOException e) fail(e,"Exception while listening for connections")  
  40.     }  
  41.     // 啟動(dòng)服務(wù)器主程序  
  42.     public static void main(String args[])  
  43.     {  
  44.     int port = 0;  
  45.     if (args.length == 1)  
  46.     {  
  47.     try port = Integer.parseInt(args[0]);  
  48.     catch(NumberFormatException e) port = 0;  
  49.     }  
  50.     new Server(port);  
  51.     // End of the main  
  52.     } // End of Server class  
  53.     //以下定義了Connection 類,它是用來(lái)處理與客戶機(jī)的所有通信的線程。  
  54.     class Connection extends Thread  
  55.     {  
  56.     protected Socket client;  
  57.     protected DataInputStream in;  
  58.     protected PrintStream out;  
  59.     // 初始化通信流并啟動(dòng)線程  
  60.     public Connection(Socket client_socket)  
  61.     {  
  62.     client = client_socket;  
  63.     try 
  64.     {  
  65.     in = new DataInputStream(client.getinputStream());  
  66.     out = new PrintStream(client.getOutputStream());  
  67.     }  
  68.     catch(IOException e)  
  69.     {  
  70.     try client.close();  
  71.     catch(IOException e2);  
  72.     System.err.println("Exception while getting socket streram: " + e);  
  73.     Return;  
  74.     }  
  75.     this.start;  
  76.     } // End of Connection method  
  77.     // 服務(wù)例程:讀出一行文本;反轉(zhuǎn)文本;返回文本。  
  78.     public void run()  
  79.     {  
  80.     String line;  
  81.     StringBuffer revline;  
  82.     int len;  
  83.     try 
  84.     {  
  85.     for(;;)  
  86.     {  
  87.     // Read a line  
  88.     line = in.readline();  
  89.     if(line == nullbreak;  
  90.     // Reverse the line  
  91.     len = line.length();  
  92.     revline = new StringBuffer(len);  
  93.     for(int i = len-1; i >=0; i--)  
  94.     revline.insert(len-1-I;line.charAt(i));  
  95.     // Write out the reverse line  
  96.     out.println(revline);  
  97.     }  
  98.     catch(IOException e);  
  99.     finally try client.close();  
  100.     catch(IOException e2);  
  101.     }  
  102.     // End of run method  
  103.     }  
  104.     // End of Connection class 

  四. 編寫客戶機(jī)類Java 程序

  1. // Client.java  
  2.     import java.io.*;  
  3.     import java.net.*;  
  4.     public class Client extends 
  5.     {  
  6.     public static final int Default_Port = 6543;  
  7.     // 定義出錯(cuò)例程  
  8.     public static final void usage()  
  9.     {  
  10.     System.out.println("Usage: Java Client []");  
  11.     System.exit(0);  
  12.     }  
  13.     public static void main(String args[])  
  14.     {  
  15.     int port = Default_Port;  
  16.     Socket s = null;  
  17.     // 解析端口參數(shù)  
  18.     if ((args.length != 1)&&(args.length != 2 )) usage();  
  19.     if (args.length == 1)  
  20.     port = Default_Port;  
  21.     else 
  22.     {  
  23.     try port = Integer.parseInt(args[1]);  
  24.     catch(NumberFormaatException e) usage();  
  25.     }  
  26.     try{  
  27.     // 產(chǎn)生一個(gè)Socket ,通過(guò)指定的端口與主機(jī)通信。  
  28.     s = new Socket(args[0], port);  
  29.     // 產(chǎn)生用于發(fā)出和接收的文本字符流  
  30.     DataInputStream sin = new DataInputStream(s.getInputStream());  
  31.     PrintStream sout = new DataInputStream(s.getInputStream());  
  32.     // 從控制臺(tái)讀入字符流  
  33.     DataInputStream in = new DataInputStream(System.in);  
  34.     // 返回連接的地址和端口  
  35.     ystem.out.println("Connected to"+s.getInetAddress()+":"+ s.getPort());  
  36.     String line;  
  37.     For(;;)  
  38.     {  
  39.     // 顯示提示符  
  40.     System.out.print(" >");  
  41.     System.out.flush();  
  42.     // 讀入控制臺(tái)輸入的一行字符  
  43.     line = in.readline();  
  44.     if (line == nullbreak;  
  45.     // 將接收的文本行送至服務(wù)器  
  46.     sout.println(line);  
  47.     // 從服務(wù)器接收一行字符  
  48.     line = sin.readline();  
  49.     // Check if connection is closed(i.e. for EOF)  
  50.     if(line == null)  
  51.     {  
  52.     System.out.println("Connection closed by server.");  
  53.     Break;  
  54.     }  
  55.     // 在控制臺(tái)上顯示接收的字符  
  56.     System.out.println(line);  
  57.     }  
  58.     // End of for loop  
  59.     }  
  60.     // End of try  
  61.     catch(IOException e ) System.err.println(e);  
  62.     // Always be sure to close the socket  
  63.     finally 
  64.     {  
  65.     try if(s != null) s.close();  
  66.     catch(IOException e2);  
  67.     }  
  68.     } // End of main  
  69.     } // End of Client  

  運(yùn)行該客戶機(jī)程序時(shí),必須以服務(wù)器主機(jī)名作為***個(gè)參數(shù),服務(wù)器端口號(hào)為第二個(gè)參數(shù),其中服務(wù)器端口號(hào)可缺省。

【編輯推薦】

  1. 8.4 Client/Server工作模式
  2. 學(xué)習(xí)java編程的八大優(yōu)勢(shì)
  3. 用Java做互聯(lián)網(wǎng)開(kāi)發(fā)優(yōu)勢(shì)何在?
  4. 20道Java入門習(xí)題
  5. 高手支招 Java經(jīng)驗(yàn)分享(一)
責(zé)任編輯:韓亞珊 來(lái)源: 中國(guó)IT實(shí)驗(yàn)室
相關(guān)推薦

2011-05-17 10:49:55

OracleSQL Server

2011-04-01 12:19:21

SQL Server商業(yè)智能

2012-09-04 14:52:28

Puppet

2010-08-06 12:34:15

NFS ServerClient

2010-07-27 10:38:02

NFS ServerNFS Client

2009-06-11 13:52:25

協(xié)同軟件Java

2010-09-25 11:32:06

cisco dhcp

2010-06-03 18:00:28

2024-12-17 07:41:34

Java逃逸分析

2010-07-06 15:02:12

SQL Server

2011-07-15 16:30:19

WINS

2017-09-04 14:40:00

LimitLatchTomcat線程

2020-05-22 10:40:33

ContinuatioJS前端

2023-12-29 09:01:10

SwiftUI空狀態(tài)Product?

2009-04-16 17:03:12

報(bào)表開(kāi)發(fā)工具報(bào)表制作SQL Server

2010-09-27 16:07:06

JVM Server模Client模式

2010-09-27 15:17:48

JVM client模式server模式

2010-06-28 18:21:36

UML類圖設(shè)計(jì)

2009-06-17 15:43:07

2010-05-19 15:53:02

MySQL-Clien
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)