我正在创建一个服务器(现在称为Server1),它与我拥有的另一台服务器(现在称为Server2)进行通信。
我使用Wireshark来嗅探离开的包并来到Server1。
套餐一(来自wireshark): “5955 11994.023974 192.168.1.3 192.168.1.2 UDP源 端口:50000目标端口:50004“
套餐二(来自wireshark): 5958 11994.045830 192.168.1.3 192.168.1.2 ICMP目的地不可达(端口不可达)
Server1运行一个正在侦听数据报包的线程。
代码服务器1:
while (m_keepRunning)
{
try
{
TermMsg receivedMessage = null;
receivedMessage = receive(); //See this function further down
if (receivedMessage != null)
{
if (receivedMessage.getMsgType().equals(TermMsgType.ACK))
{
System.out.println("This is an ack!");
}
else
{
System.out.println("This is a response");
}
}
else
{
System.out.println("This is nothing");
}
}
接收功能:
private TermMsg receive() throws IOException, TermMsgException
{
byte[] inBuf = new byte[BUF_SIZE_RX];
DatagramPacket inData = new DatagramPacket(inBuf, BUF_SIZE_RX);
if(true == firstEncounter)
{
StartMessage startReq = getStartMsg(false);
DatagramPacket p = makeDatagramP(startReq);
socket.send(p);
firstEncounter = false;
}
socket.receive(inData);
if (inData.getLength() > 0)
{
Msg msg;
try
{
msg = Msg.createFromUdp(inData.getData());
return msg;
}
catch (TermMsgException e1)
{
return null;
}
}
else
{
try
{
Thread.sleep(100);
}
catch (InterruptedException e)
{
}
return null;
}
}
有没有人有线索? 顺便说一句......我也用:
DatagramSocket socket;
try {
socket = new DatagramSocket(50004);
}
我是否必须使用服务器套接字来监听多个数据报包?
要点: - 端口无法访问 - 无法收到第二包
希望有人可以帮助我。 提前致谢
答案 0 :(得分:1)
正如在该问题的评论中已经提到的,第一个问题是您假设以下两行是两个正在发送的UDP数据包。
Package one(from wireshark): "5955 11994.023974 192.168.1.3 192.168.1.2 UDP Source port: 50000 Destination port: 50004"
Package two(from wireshark): 5958 11994.045830 192.168.1.3 192.168.1.2 ICMP Destination unreachable (Port unreachable)
实际上,这可能是一个不完整的痕迹,因为它显示了两个包:
Package one(from wireshark): "5955 11994.023974 192.168.1.3 192.168.1.2 UDP Source port: 50000 Destination port: 50004"
这是一个UDP数据包,从server2(192.168.1.3)到server1(192.168.1.2)。它将被发送到server1上的端口50004。
Package two(from wireshark): 5958 11994.045830 192.168.1.3 192.168.1.2 ICMP Destination unreachable (Port unreachable)
这是从server2发送到server1的控制消息,表示由于目标端口未打开而无法传送先前的数据包。这是从server1到server2的先前数据包传递尝试的答案,该尝试不起作用。这可能有助于解释为什么你没有得到你期望的所有数据包?