溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

UDP DUP超時如何使用UPD端口狀態(tài)檢測

發(fā)布時間:2020-10-26 18:08:38 來源:億速云 閱讀:217 作者:Leah 欄目:開發(fā)技術(shù)

今天就跟大家聊聊有關(guān)UDP DUP超時如何使用UPD端口狀態(tài)檢測,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

ds.setSoTimeout(5000);即為收數(shù)超時時間,如果不設(shè)置,那就是等待,比電視劇里面愛情片都漫長的等待,而且結(jié)果是一樣的,都是把自己等死了就不再等了。但是這個超時時間不能當(dāng)作是你這個請求的超時時間,請注意這個概念,因為這個超時只是用于標(biāo)記這段時間沒有從網(wǎng)絡(luò)中獲取數(shù)據(jù),但是即使獲取數(shù)據(jù)了,那也不一定是你的,這個下面看示例就會明白。

然后就是端口問題,上面也說了你可以自己指定端口,也可以是把自己當(dāng)作客戶端,需要發(fā)送數(shù)據(jù)時就創(chuàng)建一個連接對象然后發(fā)送數(shù)據(jù),這樣端口就是動態(tài)的。意思就是說,只要DatagramSocket對象沒有被重新初始化或消失,那么本地打開的這個UDP端口就不會關(guān)閉。

然后就是UDP狀態(tài)的問題,其實早先就也有一篇文章了, UDP連接對象的理解和使用。無狀態(tài)是說這個連接沒有狀態(tài),鬼知道他到底有沒有服務(wù)端,鬼也不知道就算那個服務(wù)端在他到底死了沒有。但是對于本地來說,如果你的DatagramSocket對象一直存在,那么你的本地端口就是有狀態(tài)的,他是活的。

然后做一個示例:

package test;
import java.io.*;
import java.net.*;
import java.util.Arrays;
/**
 * UDP客戶端程序,用于對服務(wù)端發(fā)送數(shù)據(jù),并接收服務(wù)端的回應(yīng)信息
 */
public class UdpClientSocket {
	private byte[] buffer = new byte[1024];
	private static DatagramSocket ds = null;
	/**
	 * 測試客戶端發(fā)包和接收回應(yīng)信息的方法
	 */
	public static void main(String[] args) throws Exception {
		UdpClientSocket client = new UdpClientSocket();
		String serverHost = "127.0.0.1";
		int serverPort = 10002;
		client.send(serverHost, serverPort, new byte[]{1,2,3,4,5});
		while(true){
			byte[] bt = client.receive();
			if(null != bt && bt.length > 0)
				System.out.println("收到數(shù)據(jù):" + Arrays.toString(bt));
			Thread.sleep(1000);
		}
	}
	/**
	 * 構(gòu)造函數(shù),創(chuàng)建UDP客戶端
	 */
	public UdpClientSocket() throws Exception {
		ds = new DatagramSocket(8899); // 邦定本地端口作為客戶端
		ds.setSoTimeout(5000);
	}
	/**
	 * 向指定的服務(wù)端發(fā)送數(shù)據(jù)信息
	 */
	public final void send(final String host, final int port,final byte[] bytes) throws IOException {
		DatagramPacket dp = new DatagramPacket(bytes, bytes.length, InetAddress.getByName(host), port);
		ds.send(dp);
	}
	/**
	 * 接收從指定的服務(wù)端發(fā)回的數(shù)據(jù)
	 */
	public final byte[] receive() throws Exception {
		try {
			DatagramPacket dp = new DatagramPacket(buffer, buffer.length);
			ds.receive(dp);		
			byte[] data = new byte[dp.getLength()];
			System.arraycopy(dp.getData(), 0, data, 0, dp.getLength());		
			return data;
		} catch (Exception e) {
			e.printStackTrace();
			return null;
		}
	}
}

運行一直報錯:

java.net.SocketTimeoutException: Receive timed out
at java.net.PlainDatagramSocketImpl.receive0(Native Method)
at java.net.PlainDatagramSocketImpl.receive(PlainDatagramSocketImpl.java:136)
at java.net.DatagramSocket.receive(DatagramSocket.java:712)
at test.UdpClientSocket.receive(UdpClientSocket.java:46)
at test.UdpClientSocket.main(UdpClientSocket.java:20)
java.net.SocketTimeoutException: Receive timed out
at java.net.PlainDatagramSocketImpl.receive0(Native Method)
at java.net.PlainDatagramSocketImpl.receive(PlainDatagramSocketImpl.java:136)
at java.net.DatagramSocket.receive(DatagramSocket.java:712)
at test.UdpClientSocket.receive(UdpClientSocket.java:46)
at test.UdpClientSocket.main(UdpClientSocket.java:20)

使用TCPUDPDbg向8899發(fā)送數(shù)據(jù),可以收到:

收到數(shù)據(jù):[16, 17, 18, 19, 20]

這里示例中已經(jīng)寫明

1.本地端口是8899

2.收數(shù)超時時間是5秒

3.向本地10002端口發(fā)送了一組數(shù)據(jù),鬼知道有沒有收到

4.不斷獲取本地端口8899收到的UDP數(shù)據(jù)

然后發(fā)現(xiàn)

1.發(fā)送數(shù)據(jù)沒有報錯

2.一直報錯收數(shù)超時

3.使用TCPUDPDbg向8899發(fā)送數(shù)據(jù)能夠收到

總結(jié):

1.UDP能指定收數(shù)超時,但是每個請求的超時需要自己控制

2.UDP可以邦定本地端口發(fā)數(shù),而且這個端口可以有狀態(tài)存活

3.UDP沒有狀態(tài),但是本地可以有

看完上述內(nèi)容,你們對UDP DUP超時如何使用UPD端口狀態(tài)檢測有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)
推薦閱讀:
  1. DHCP、UDP
  2. TCP與UDP

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI