亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長資訊網(wǎng)
    最全最豐富的資訊網(wǎng)站

    JAVA進階學習之Socket編程

    本篇文章給大家?guī)砹岁P于java的相關知識,其中主要介紹了關于socket編程的相關內(nèi)容,Socket是網(wǎng)絡驅(qū)動層提供給應用程序的一個接口或者說一種機制,下面一起來看一下,希望對大家有幫助。

    JAVA進階學習之Socket編程

    程序員必備接口測試調(diào)試工具:立即使用
    Apipost = Postman + Swagger + Mock + Jmeter
    Api設計、調(diào)試、文檔、自動化測試工具
    后端、前端、測試,同時在線協(xié)作,內(nèi)容實時同步

    推薦學習:《java視頻教程》

    一、Socket知識

    1. Socket概述

    (1)Java最初是作為網(wǎng)絡編程語言出現(xiàn)的,它對網(wǎng)絡的高度支持,使得客戶端和服務器端流暢的溝通成為現(xiàn)實。

    (2)在網(wǎng)絡編程中,使用最多的就是Socket,每一個實用的網(wǎng)絡程序都少不了它的參與。

    (3)在計算機網(wǎng)絡編程技術中,兩個進程或者說兩臺計算機可以通過一個網(wǎng)絡通信連接實現(xiàn)數(shù)據(jù)的交換,這種通信鏈路的端點就被稱為“套接字”(英文名稱也就是Socket)。

    (4)Socket是網(wǎng)絡驅(qū)動層提供給應用程序的一個接口或者說一種機制。

    (5)使用物流送快遞的例子來說明Socket:

    –>發(fā)件人將有收貨人地址信息的貨物送到快遞站,發(fā)件人不用關心物流是如何進行的,貨物被送到收貨人所在地區(qū)的快遞站點,進行配送,收貨人等待收貨就可以了。

    –>這個過程很形象地說明了信息在網(wǎng)絡中傳遞的過程。其中,貨物就是數(shù)據(jù)信息,2個快遞站點就是2個端點Socket。

    JAVA進階學習之Socket編程

    (6)信息如何在網(wǎng)絡中尋址傳遞,應用程序并不用關心,只負責準備發(fā)送數(shù)據(jù)和接收數(shù)據(jù)即可。

    2. Socket通信原理

    (1)對于編程人員來說,無須了解Socket底層機制是如何傳送數(shù)據(jù)的,而是直接將數(shù)據(jù)提交給Socket,Socket會根據(jù)應用程序提供的相關信息,通過一系列計算,綁定IP及信息數(shù)據(jù),將數(shù)據(jù)交給驅(qū)動程序向網(wǎng)絡上發(fā)送。

    (2)Socket的底層機制非常復雜,Java平臺提供了一些簡單但是強大的類,可以簡單有效地使用Socket開發(fā)通信程序而無須了解底層機制。

    3. java.net包

    (1)java.net包提供了若干支持基于套接字的客戶端/服務器通信的類。

    (2)java.net包中常用的類有Socket、ServerSocket、DatagramPacket、DatagramSocket、InetAddress、URL、URLConnection和URLEncoder等。

    (3)為了監(jiān)聽客戶端的連接請求,可以使用ServerSocket類。

    (4)Socket類實現(xiàn)用于網(wǎng)絡上進程間通信的套接字。

    (5)DatagramSocket類使用UDP協(xié)議實現(xiàn)客戶端和服務器套接字。

    (6)DatagramPacket類使用DatagramSocket類的對象封裝設置和收到的數(shù)據(jù)報。

    (7)InetAddress類表示Internet地址。

    (8)在創(chuàng)建數(shù)據(jù)報報文和Socket對象時,可以使用InetAddress類

    二、基于TCP協(xié)議的Socket編程

    1.Socket類和ServerSocket類

    (1)java.net包的兩個類Socket和ServerSocket,分別用來實現(xiàn)雙向安全連接的客戶端和服務器端,它們是基于TCP協(xié)議進行工作的,工作過程如同打電話的過程,只有雙方都接通了,才能開始通話。

    (2)進行網(wǎng)絡通信時,Socket需要借助數(shù)據(jù)流來完成數(shù)據(jù)的傳遞工作。

    (3)一個應用程序要通過網(wǎng)絡向另一個應用程序發(fā)送數(shù)據(jù),只要簡單地創(chuàng)建Socket,然后將數(shù)據(jù)寫入到與該Socket關聯(lián)的輸出流即可。對應的,接收方的應用程序創(chuàng)建Socket,從相關聯(lián)的輸入流讀取數(shù)據(jù)即可。

    (4)注意:2個端點在基于TCP協(xié)議的Socket編程中,經(jīng)常一個作為客戶端,一個作為服務器端,也就是遵循client-server模型。

    ● Socket類

    Socket對象在客戶端和服務器之間建立連接??捎肧ocket類的構造方法創(chuàng)建套接字,并將此套接字連接至指定的主機和端口。

    (1)構造方法

    –>第一種構造方法以主機名和端口號作為參數(shù)來創(chuàng)建一個Socket對象。創(chuàng)建對象時可能拋出UnknownHostException或IOException異常,必須捕獲它們。

    Socket s = new Socket(hostName,port);

    –>第二種構造方法以InetAddress對象和端口號作為參數(shù)來創(chuàng)建一個Socket對象。構造方法可能拋出IOException或UnknownHostException異常,必須捕獲并處理它們。

    Socket s = new Socket(address,port);

    (2)常用方法
    JAVA進階學習之Socket編程

    ● ServerSocket類

    ServerSocket對象等待客戶端建立連接,連接建立以后進行通信。

    (1)構造方法

    –>第一種構造方法接受端口號作為參數(shù)創(chuàng)建ServerSocket對象,創(chuàng)建此對象時可能拋出IOException異常,必須捕獲和處理它。

    ServerSocket ss = new ServerSocket(port);

    –>第二種構造方法接受端口號和最大隊列長度作為參數(shù),隊列長度表示系統(tǒng)在拒絕連接前可以擁有的最大客戶端連接數(shù)。

    ServerSocket ss = new ServerSocket(port,maxqu);

    (2)常用方法

    –>Socket類中列出的方法也適用于ServerSocket類。

    –>ServerSocket類具有accept()方法,此方法用于等待客戶端發(fā)起通信,這樣Socket對象就可用于進一步的數(shù)據(jù)傳輸。

    2.使用Socket編程實現(xiàn)登錄功能

    JAVA進階學習之Socket編程

    ● 實現(xiàn)單用戶登錄

    –>Socket網(wǎng)絡編程一般分成如下4個步驟進行:

    (1)建立連接。

    (2)打開Socket關聯(lián)的輸入/輸出流。

    (3)從數(shù)據(jù)流中寫入信息和讀取信息。

    (4)關閉所有的數(shù)據(jù)流和Socket。

    –>使用兩個類模擬實現(xiàn)用戶登錄的功能,實現(xiàn)客戶端向服務器端發(fā)送用戶登錄信息,服務器端顯示這些信息。

    客戶端實現(xiàn)步驟:

    1)建立連接,連接指向服務器及端口。

    2)打開Socket關聯(lián)的輸入/輸出流。

    3)向輸出流中寫入信息。

    4)從輸入流中讀取響應信息。

    5)關閉所有的數(shù)據(jù)流和Socket。

    服務器端實現(xiàn)步驟:

    1)建立連接,監(jiān)聽端口。

    2)使用accept()方法等待客戶端發(fā)起通信

    3)打開Socket關聯(lián)的輸入/輸出流。

    4)從輸入流中讀取請求信息。

    5)向輸出流中寫入信息。

    6)關閉所有的數(shù)據(jù)流和Socket。

    –>客戶端和服務器端的交互,采用一問一答的模式,先啟動服務器進入監(jiān)聽狀態(tài),等待客戶端的連接請求,連接成功以后,客戶端先“發(fā)言”,服務器給予“回應”。

    示例01:實現(xiàn)傳遞對象信息。

    ♥ user類

    package cn.bdqn.demo02;  import java.io.Serializable;  public class User implements Serializable {  	private static final long serialVersionUID = 1L; 	/** 用戶名 */ 	private String loginName; 	/** 用戶密碼 */ 	private String pwd;  	public User() { 		super(); 	}  	public User(String loginName, String pwd) { 		super(); 		this.loginName = loginName; 		this.pwd = pwd; 	}  	public String getLoginName() { 		return loginName; 	}  	public void setLoginName(String loginName) { 		this.loginName = loginName; 	}  	public String getPwd() { 		return pwd; 	}  	public void setPwd(String pwd) { 		this.pwd = pwd; 	}  }
    登錄后復制

    ♥ LoginServer類

    package cn.bdqn.demo02;  import java.io.IOException; import java.io.InputStream; import java.io.ObjectInputStream; import java.io.OutputStream; import java.net.ServerSocket; import java.net.Socket;  public class LoginServer {  	public static void main(String[] args) { 		ServerSocket serverSocket = null; 		Socket socket = null; 		InputStream is = null; 		ObjectInputStream ois = null; 		OutputStream os = null; 		try { 			// 建立一個服務器Socket(ServerSocket),指定端口8800并開始監(jiān)聽 			serverSocket = new ServerSocket(8800); 			// 使用accept()方法等待客戶端發(fā)起通信 			socket = serverSocket.accept(); 			// 打開輸入流 			is = socket.getInputStream(); 			// 反序列化 			ois = new ObjectInputStream(is); 			// 獲取客戶端信息,即從輸入流讀取信息 			User user = (User) ois.readObject(); 			if (user != null) { 				System.out.println("我是服務器,客戶登錄信息為:" + user.getLoginName() + "," 						+ user.getPwd()); 			}  			// 給客戶端一個響應,即向輸出流中寫入信息 			String reply = "歡迎你,登錄成功"; 			os = socket.getOutputStream(); 			os.write(reply.getBytes()); 		} catch (IOException e) { 			e.printStackTrace(); 		} catch (ClassNotFoundException e) { 			e.printStackTrace(); 		} finally { 			// 關閉資源 			try { 				os.close(); 				ois.close(); 				is.close(); 				socket.close(); 				serverSocket.close(); 			} catch (IOException e) { 				e.printStackTrace(); 			} 		} 	} }
    登錄后復制

    LoginClient類

    package cn.bdqn.demo02;  import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.ObjectOutputStream; import java.io.OutputStream; import java.net.Socket; import java.net.UnknownHostException;  public class LoginClient {  	/* 	 * 示例02:升級演示示例01,實現(xiàn)傳遞對象信息。 	 */ 	 	public static void main(String[] args) { 		Socket socket = null; 		OutputStream os = null; 		ObjectOutputStream oos = null; 		InputStream is = null; 		BufferedReader br = null; 		try { 			// 建立客戶端Socket連接,指定服務器的位置為本機以及端口為8800 			socket = new Socket("localhost", 8800); 			// 打開輸出流 			os = socket.getOutputStream(); 			// 對象序列化 			oos = new ObjectOutputStream(os); 			// 發(fā)送客戶端信息,即向輸出流中寫入信息 			User user = new User("Tom", "123456"); 			oos.writeObject(user); 			socket.shutdownOutput();  			// 接收服務器端的響應,即從輸入流中讀取信息 			is = socket.getInputStream(); 			br = new BufferedReader(new InputStreamReader(is)); 			String reply; 			while ((reply = br.readLine()) != null) { 				System.out.println("我是客戶端,服務器的響應為:" + reply); 			} 		} catch (UnknownHostException e) { 			e.printStackTrace(); 		} catch (IOException e) { 			e.printStackTrace(); 		} finally { 			try { 				br.close(); 				is.close(); 				oos.close(); 				os.close(); 				socket.close(); 			} catch (IOException e) { 				e.printStackTrace(); 			} 		} 	} }
    登錄后復制

    示例02:升級演示示例01,實現(xiàn)傳遞多個對象信息。

    user類

    package cn.bdqn.demo03;  import java.io.Serializable;  public class User implements Serializable {  	private static final long serialVersionUID = 1L; 	/** 用戶名 */ 	private String loginName; 	/** 用戶密碼 */ 	private String pwd;  	public User() { 		super(); 	}  	public User(String loginName, String pwd) { 		super(); 		this.loginName = loginName; 		this.pwd = pwd; 	}  	public String getLoginName() { 		return loginName; 	}  	public void setLoginName(String loginName) { 		this.loginName = loginName; 	}  	public String getPwd() { 		return pwd; 	}  	public void setPwd(String pwd) { 		this.pwd = pwd; 	}  }
    登錄后復制

    LoginServer類

    package cn.bdqn.demo03;  import java.io.IOException; import java.io.InputStream; import java.io.ObjectInputStream; import java.io.OutputStream; import java.net.ServerSocket; import java.net.Socket;  public class LoginServer {  	public static void main(String[] args) { 		ServerSocket serverSocket = null; 		Socket socket = null; 		InputStream is = null; 		ObjectInputStream ois = null; 		OutputStream os = null; 		try { 			// 建立一個服務器Socket(ServerSocket),指定端口8800并開始監(jiān)聽 			serverSocket = new ServerSocket(8800); 			// 使用accept()方法等待客戶端發(fā)起通信 			socket = serverSocket.accept(); 			// 打開輸入流 			is = socket.getInputStream(); 			// 反序列化 			ois = new ObjectInputStream(is); 			// 獲取客戶端信息,即從輸入流讀取信息 			User[] users = (User[]) ois.readObject(); 			for (int i = 0; i < users.length; i++) { 				System.out.println("我是服務器,客戶登錄信息為:" + users[i].getLoginName() 						+ "," + users[i].getPwd()); 			}  			// 給客戶端一個響應,即向輸出流中寫入信息 			String reply = "歡迎你,登錄成功"; 			os = socket.getOutputStream(); 			os.write(reply.getBytes()); 		} catch (IOException e) { 			e.printStackTrace(); 		} catch (ClassNotFoundException e) { 			e.printStackTrace(); 		} finally { 			// 關閉資源 			try { 				os.close(); 				ois.close(); 				is.close(); 				socket.close(); 				serverSocket.close(); 			} catch (IOException e) { 				e.printStackTrace(); 			} 		} 	} }
    登錄后復制

    LoginClient類

    package cn.bdqn.demo03;  import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.ObjectOutputStream; import java.io.OutputStream; import java.net.Socket; import java.net.UnknownHostException;  public class LoginClient {  	/* 	 * 示例02:升級演示示例01,實現(xiàn)傳遞對象信息。 	 */ 	 	public static void main(String[] args) { 		Socket socket = null; 		OutputStream os = null; 		ObjectOutputStream oos = null; 		InputStream is = null; 		BufferedReader br = null; 		try { 			// 建立客戶端Socket連接,指定服務器的位置為本機以及端口為8800 			socket = new Socket("localhost", 8800); 			// 打開輸出流 			os = socket.getOutputStream(); 			// 對象序列化 			oos = new ObjectOutputStream(os); 			// 發(fā)送客戶端信息,即向輸出流中寫入信息 			User user1 = new User("Tom", "123456"); 			User user2 = new User("bob", "123456"); 			User user3 = new User("lisa", "123456"); 			User[] users = {user1,user2,user3}; 			oos.writeObject(users); 			socket.shutdownOutput();  			// 接收服務器端的響應,即從輸入流中讀取信息 			is = socket.getInputStream(); 			br = new BufferedReader(new InputStreamReader(is)); 			String reply; 			while ((reply = br.readLine()) != null) { 				System.out.println("我是客戶端,服務器的響應為:" + reply); 			} 		} catch (UnknownHostException e) { 			e.printStackTrace(); 		} catch (IOException e) { 			e.printStackTrace(); 		} finally { 			try { 				br.close(); 				is.close(); 				oos.close(); 				os.close(); 				socket.close(); 			} catch (IOException e) { 				e.printStackTrace(); 			} 		} 	} }
    登錄后復制

    ● 實現(xiàn)多客戶端用戶登錄

    JAVA進階學習之Socket編程

    –>一問一答的模式在現(xiàn)實中顯然不是人們想要的。一個服務器不可能只針對一個客戶端服務,一般是面向很多的客戶端同時提供服務的,但是單線程實現(xiàn)必然是這樣的結果。

    –>解決這個問題的辦法是采用多線程的方式,可以在服務器端創(chuàng)建一個專門負責監(jiān)聽的應用主服務程序、一個專門負責響應的線程程序。這樣可以利用多線程處理多個請求。

    ->客戶端實現(xiàn)步驟:

    1)建立連接,連接指向服務器及端口。

    2)打開Socket關聯(lián)的輸入/輸出流。

    3)向輸出流中寫入信息。

    4)從輸入流中讀取響應信息。

    5)關閉所有的數(shù)據(jù)流和Socket。

    –>服務器端實現(xiàn)步驟:

    1)創(chuàng)建服務器線程類,run()方法中實現(xiàn)對一個請求的響應處理。

    2)修改服務器端代碼,讓服務器端Socket一直處于監(jiān)聽狀態(tài)。

    3)服務器端每監(jiān)聽到一個請求,創(chuàng)建一個線程對象并啟動。

    示例03:升級演示示例02,實現(xiàn)多客戶端的響應處理。

    user類

    package cn.bdqn.demo04;  import java.io.Serializable;  public class User implements Serializable {  	private static final long serialVersionUID = 1L; 	/** 用戶名 */ 	private String loginName; 	/** 用戶密碼 */ 	private String pwd;  	public User() { 		super(); 	}  	public User(String loginName, String pwd) { 		super(); 		this.loginName = loginName; 		this.pwd = pwd; 	}  	public String getLoginName() { 		return loginName; 	}  	public void setLoginName(String loginName) { 		this.loginName = loginName; 	}  	public String getPwd() { 		return pwd; 	}  	public void setPwd(String pwd) { 		this.pwd = pwd; 	}  }
    登錄后復制

    LoginThread

    package cn.bdqn.demo04;  import java.io.IOException; import java.io.InputStream; import java.io.ObjectInputStream; import java.io.OutputStream; import java.net.Socket;  public class LoginThread extends Thread { 	/* 	 * 示例03:升級示例02,實現(xiàn)多客戶端的響應處理。 	 *  	 * 分析如下: 	 * 	(1)創(chuàng)建服務器端線程類,run()方法中實現(xiàn)對一個請求的響應處理。 	 * 	(2)修改服務器端代碼,讓服務器端Socket一直處于監(jiān)聽狀態(tài)。 	 * 	(3)服務器端每監(jiān)聽到一個請求,創(chuàng)建一個線程對象并啟動 	 */ 	 	Socket socket = null; 	//每啟動一個線程,連接對應的Socket  	public LoginThread(Socket socket) { 		this.socket = socket; 	} 	 	//啟動線程,即響應客戶請求 	public void run() { 		InputStream is = null; 		ObjectInputStream ois = null; 		OutputStream os = null; 		try { 			//打開輸入流 			is = socket.getInputStream(); 			//反序列化 			ois = new ObjectInputStream(is); 			//獲取客戶端信息,即從輸入流讀取信息 			User user = (User)ois.readObject(); 			if(user!=null){ 				System.out.println("我是服務器,客戶登錄信息為:"+user.getLoginName()+","+user.getPwd()); 			} 			 			//給客戶端一個響應,即向輸出流中寫入信息 			os = socket.getOutputStream(); 			String reply = "歡迎你,登錄成功"; 			os.write(reply.getBytes()); 		} catch (IOException e) { 			e.printStackTrace(); 		} catch (ClassNotFoundException e) { 			e.printStackTrace(); 		}finally{ 			try { 				os.close(); 				ois.close(); 				is.close(); 				socket.close(); 			} catch (IOException e) { 				e.printStackTrace(); 			}			 		}	 	}	 }
    登錄后復制

    LoginServer類

    package cn.bdqn.demo04;  import java.io.IOException; import java.net.ServerSocket; import java.net.Socket;  public class LoginServer { 	 	public static void main(String[] args) { 		 		ServerSocket serverSocket = null; 		try { 			// 建立一個服務器Socket(ServerSocket)指定端口并開始監(jiān)聽 			serverSocket = new ServerSocket(8800);  			// 監(jiān)聽一直進行中 			while (true) { 				// 使用accept()方法等待客戶發(fā)起通信 				Socket socket = serverSocket.accept(); 				LoginThread loginThread = new LoginThread(socket); 				loginThread.start(); 			} 		} catch (IOException e) { 			e.printStackTrace(); 		} 	} }
    登錄后復制

    ♥ LoginClient1類

    package cn.bdqn.demo04;  import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.ObjectOutputStream; import java.io.OutputStream; import java.net.Socket; import java.net.UnknownHostException;  public class LoginClient01 { 	/* 	 * 客戶端通過輸出流向服務器端發(fā)送請求信息 	 * 服務器偵聽客戶端的請求得到一個Socket對象,將這個Socket對象傳遞給線程類 	 * 線程類通過輸入流獲取客戶端的請求并通過輸出流向客戶端發(fā)送響應信息 	 * 客戶端通過輸入流讀取服務器發(fā)送的響應信息 	 *  	 */  	/* 	 * 示例03:升級演示示例02,實現(xiàn)多客戶端的響應處理 	 */ 	public static void main(String[] args) { 		 		Socket socket = null; 		OutputStream os = null; 		ObjectOutputStream oos = null; 		InputStream is = null; 		BufferedReader br = null; 		try { 			// 建立客戶端Socket連接,指定服務器的位置為本機以及端口為8800 			socket = new Socket("localhost", 8800); 			// 打開輸出流 			os = socket.getOutputStream(); 			// 對象序列化 			oos = new ObjectOutputStream(os); 			// 發(fā)送客戶端信息,即向輸出流中寫入信息 			User user = new User("Tom", "123456"); 			oos.writeObject(user); 			socket.shutdownOutput();  			// 接收服務器端的響應,即從輸入流中讀取信息 			is = socket.getInputStream(); 			br = new BufferedReader(new InputStreamReader(is)); 			String reply; 			while ((reply = br.readLine()) != null) { 				System.out.println("我是客戶端,服務器的響應為:" + reply); 			} 		} catch (UnknownHostException e) { 			e.printStackTrace(); 		} catch (IOException e) { 			e.printStackTrace(); 		} finally { 			try { 				br.close(); 				is.close(); 				oos.close(); 				os.close(); 				socket.close(); 			} catch (IOException e) { 				e.printStackTrace(); 			} 		} 	} }
    登錄后復制

    ♥ LoginClient2類和LoginClient3類

    同LoginClient1類一樣,創(chuàng)建不同的User對象即可

    –>java.net包中的InetAddress類用于封裝IP地址和DNS。要創(chuàng)建InetAddress類的實例,可以使用工廠方法,因為此類沒有構造方法。

    –>InetAddress類中的工廠方法JAVA進階學習之Socket編程

    –>如果找不到主機,兩種方法都將拋出UnknownHostNameException異常。

    三、基于UDP協(xié)議的Socket編程

    TCP UDP
    是否連接 面向連接 面向非連接
    傳輸可靠性 可靠 不可靠
    速度

    1.DatagramPacket類和DatagramSocket類

    (1)基于TCP的網(wǎng)絡通信是安全的,是雙向的,如同打電話,需要先有服務端,建立雙向連接后,才開始數(shù)據(jù)通信。

    (2)基于UDP的網(wǎng)絡通信只需要指明對方地址,然后將數(shù)據(jù)送出去,并不會事先連接。這樣的網(wǎng)絡通信是不安全的,所以只應用在如聊天系統(tǒng)、咨詢系統(tǒng)等場合下。

    (3)數(shù)據(jù)報是表示通信的一種報文類型,使用數(shù)據(jù)報進行通信時無須事先建立連接,它是基于UDP協(xié)議進行的。

    (4)Java中有兩個可使用數(shù)據(jù)報實現(xiàn)通信的類,即DatagramPacketDatagramSocket。

    (5)DatagramPacket類起到容器的作用,DatagramSocket類用于發(fā)送或接收DatagramPacket。

    (6)DatagramPacket類不提供發(fā)送或接收數(shù)據(jù)的方法,而DatagramSocket類提供send()方法和receive()方法,用于通過套接字發(fā)送和接收數(shù)據(jù)報。

    ● DatagramPacket類

    (1)構造方法

    –>客戶端要向外發(fā)送數(shù)據(jù),必須首先創(chuàng)建一個DatagramPacket對象,再使用DatagramSocket對象發(fā)送。

    JAVA進階學習之Socket編程

    (2)常用方法

    JAVA進階學習之Socket編程

    ● DatagramSocket類

    (1)構造方法

    –>DatagramSocket類不維護連接狀態(tài),不產(chǎn)生輸入/輸出數(shù)據(jù)流,它的唯一作用就是接收和發(fā)送DatagramPacket對象封裝好的數(shù)據(jù)報。

    JAVA進階學習之Socket編程

    (2)常用方法

    JAVA進階學習之Socket編程

    2.使用Socket編程實現(xiàn)客戶咨詢

    –>利用UDP通信的兩個端點是平等的,也就是說通信的兩個程序關系是對等的,沒有主次之分,甚至它們的代碼都可以完全是一樣的,這一點要與基于TCP協(xié)議的Socket編程區(qū)分開來。

    –>基于UDP協(xié)議的Socket網(wǎng)絡編程一般按照以下4個步驟進行:

    (1)利用DatagramPacket對象封裝數(shù)據(jù)包。

    (2)利用DatagramSocket對象發(fā)送數(shù)據(jù)包。

    (3)利用DatagramSocket對象接收數(shù)據(jù)包。

    (4)利用DatagramPacket對象處理數(shù)據(jù)包。

    JAVA進階學習之Socket編程

    –>模擬客戶咨詢功能,實現(xiàn)發(fā)送方發(fā)送咨詢問題,接收方接收并顯示發(fā)送來的咨詢問題。

    發(fā)送方實現(xiàn)步驟:

    1)獲取本地主機的InetAddress對象。

    2)創(chuàng)建DatagramPacket對象,封裝要發(fā)送的信息。

    3)利用DatagramSocket對象將DatagramPacket對象數(shù)據(jù)發(fā)送出去。

    接收方實現(xiàn)步驟:

    1)創(chuàng)建DatagramPacket對象,準備接收封裝的數(shù)據(jù)。

    2)創(chuàng)建DatagramSocket對象,接收數(shù)據(jù)保存于DatagramPacket對象中。

    3)利用DatagramPacket對象處理數(shù)據(jù)。

    示例04:發(fā)送方發(fā)送咨詢問題,接收方回應咨詢。

    ♥ Receive類

    package cn.bdqn.demo05;  import java.io.IOException; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.SocketAddress; import java.net.SocketException;  public class Receive {  	public static void main(String[] args) { 		/* 		 * 示例06:發(fā)送方發(fā)送咨詢問題,接收方回應咨詢。 		 *  		 * 接收方實現(xiàn)步驟如下:  		 * (1)創(chuàng)建DatagramPacket對象,準備接收封裝的數(shù)據(jù)。 		 * (2)創(chuàng)建DatagramSocket對象,接收數(shù)據(jù)保存于DatagramPacket對象中。 		 * (3)利用DatagramPacket對象處理數(shù)據(jù)。 		 */  		DatagramSocket ds = null; 		DatagramPacket dp = null; 		DatagramPacket dpto = null; 		// 創(chuàng)建DatagramPacket對象,用來準備接收數(shù)據(jù) 		byte[] buf = new byte[1024]; 		dp = new DatagramPacket(buf, 1024); 		try { 			// 創(chuàng)建DatagramSocket對象,接收數(shù)據(jù) 			ds = new DatagramSocket(8800); 			ds.receive(dp); 			// 顯示接收到的信息 			String mess = new String(dp.getData(), 0, dp.getLength()); 			System.out.println(dp.getAddress().getHostAddress() + "說:" + mess);  			String reply = "你好,我在,請咨詢!"; 			// 顯示與本地對話框 			System.out.println("我  說:" + reply); 			// 創(chuàng)建DatagramPacket對象,封裝數(shù)據(jù) 			SocketAddress sa = dp.getSocketAddress(); 			dpto = new DatagramPacket(reply.getBytes(), 					reply.getBytes().length, sa); 			ds.send(dpto); 		} catch (SocketException e) { 			e.printStackTrace(); 		} catch (IOException e) { 			e.printStackTrace(); 		} finally { 			ds.close(); 		} 	} }
    登錄后復制

    ♥ Send類

    package cn.bdqn.demo05;  import java.io.IOException; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.InetAddress; import java.net.SocketException; import java.net.UnknownHostException;  public class Send { 	/* 	 * 示例06:升級示例05,發(fā)送方發(fā)送咨詢問題,接收方回應咨詢。 	 *  	 * 發(fā)送方實現(xiàn)步驟如下:  	 * (1)獲取本地主機的InetAddress對象。  	 * (2)創(chuàng)建DatagramPacket對象,封裝要發(fā)送的信息。 	 * (3)利用DatagramSocket對象將DatagramPacket對象數(shù)據(jù)發(fā)送出去。 	 */  	public static void main(String[] args) { 		DatagramSocket ds = null; 		InetAddress ia = null; 		String mess = "你好,我想咨詢一個問題。"; 		System.out.println("我說:" + mess); 		try { 			// 獲取本地主機地址 			ia = InetAddress.getByName("localhost"); 			// 創(chuàng)建DatagramPacket對象,封裝數(shù)據(jù) 			DatagramPacket dp = new DatagramPacket(mess.getBytes(), 					mess.getBytes().length, ia, 8800); 			// 創(chuàng)建DatagramSocket對象,向服務器發(fā)送數(shù)據(jù) 			ds = new DatagramSocket(); 			ds.send(dp);  			byte[] buf = new byte[1024]; 			DatagramPacket dpre = new DatagramPacket(buf, buf.length); 			ds.receive(dpre); 			// 顯示接收到的信息 			String reply = new String(dpre.getData(), 0, dpre.getLength()); 			System.out.println(dpre.getAddress().getHostAddress() + "說:" 					+ reply); 		} catch (UnknownHostException e) { 			e.printStackTrace(); 		} catch (SocketException e) { 			e.printStackTrace(); 		} catch (IOException e) { 			e.printStackTrace(); 		} finally { 			ds.close(); 		} 	} }
    登錄后復制

    推薦學習:《java視頻教程》

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號