2016-04-01 37 views
1

我试图从UDP数据包中提取信息,但不断得到随机输出。有时候我会得到我想要的东西,有时我不会。解析UDP数据包后的垃圾输出

这里是我的代码:

private static void receivePacket() 
{ 
    try { 
     DatagramSocket socket = new DatagramSocket(port); 
     System.out.println("\n Listening..."); 

     while(true) 
     { 
      // Create a packet 
      DatagramPacket packet = new DatagramPacket(new byte[1024], 1024); 

      // Receive packet 
      socket.receive(packet); 
      byte[] data = packet.getData(); 

      // Parse the packet 
      parse(data, packet.getLength()); 

      socket.send(packet); 
     } 

     } catch(Exception e) { 
      e.printStackTrace(); 
     } 
} 

// Parse packets 
private static void parse(byte [] data, int dataLength) 
{ 
    ArrayList<String> name = new ArrayList<String>() 
    String domain = ""; 

    // Get ID 
    int id = ((data[0] & 0xff) << 8) + (data[1] & 0xff); 
    System.out.println("\n ID:\t\t" + id); 

    // Get domain name and number of bits for each word in domain 
    for(int i = 0; i < dataLength; i++) 
    { 
     // If the next bit is a letter then we know the current bit is the number of bits 
     if((data[i] <= ' ') || (data[i] > '~')) 
     { 
      try { 
       if((String.format("%c", data[i+1]).matches("^[a-zA-Z]$"))) 
       { 
        int dSize = Integer.parseInt(String.format("%d", data[i])); 
        name.add(Integer.toString(dSize)); 
       } 

      } catch (Exception e) { 
       //e.printStackTrace(); 
      } 
     } 
     else 
     { 
      // If current bit is letter add to ArrayList 
      try { 
       if((String.format("%c", data[i]).matches("^[a-zA-Z]$"))) 
       { 
        name.add(String.format("%c", data[i])); 
        domain += String.format("%c", data[i]); 
       } 

      } catch (Exception e) { 
       //e.printStackTrace(); 
      } 
     } 
    } 

    System.out.println(" Domain:\t" + domain); 
    System.out.print(" Name:\t\t"); 
    name.add("0"); 

    for(int i = 0; i < name.size(); i++) 
     System.out.print("\'" + name.get(i) + "\' "); 

    System.out.println(); 
} 

我使用命令dig @localhost -p 1299 test.mydomain.abc的UDP数据包发送到服务器。这是运行六次后的输出结果。输出每个时间应为以下(ID会有所不同):

ID:   64666 
Domain:  testmydomainabc 
Name:   '4' 't' 'e' 's' 't' '8' 'm' 'y' 'd' 'o' 'm' 'a' 'i' 'n' '3' 'a' 'b' 'c' '0' 

然而,它并不像你在这里看到从运行#开始4: enter image description here

它是完全随机的,我不不明白为什么。我在Java和Windows 10上编写这个代码。任何帮助将不胜感激,谢谢!

原始数据:

试制成功:'4' 't' 'e' 's' 't' '8' 'm' 'y' 'd' 'o' 'm' 'a' 'i' 'n' '3' 'a' 'b' 'c' '0'

b7 01 20 00 01 00 00 00 00 00 01 04 t e s t 08 m y d o m a i n 03 a b c 00 00 01 00 01 00 00) 10 00 00 00 00 00 00 00

不成功:'-127' 'f' '4' 't' 'e' 's' 't' '8' 'm' 'y' 'd' 'o' 'm' 'a' 'i' 'n' '3' 'a' 'b' 'c' '0'

81 f 01 20 00 01 00 00 00 00 00 01 04 t e s t 08 m y d o m a i n 03 a b c 00 00 01 00 01 00 00) 10 00 00 00 00 00 00 00

+1

这可能是有用的简单地打印出存储在'packet.getData()的原始数据'看无论问题发生在联网还是解析算法中。 (当然这对于添加到问题主体也是有用的) – snickers10m

+0

不确定这是您寻找的内容,但我添加了所有我收到的位。 –

+1

在正确的轨道上。我要求提供产生预期产出的试验的原始数据,以及产生不良产出的试验的原始数据。然后我们可以比较两者(并改进您的解析算法来处理我们发现的问题)。 – snickers10m

回答

1

你的循环从开始,可能应该从2开始。否则ID字节将被包括在解析(或投掷所silenty忽略异常)

+0

谢谢,snickers10m实际上帮助我弄清楚了上述情况。我将从'2'开始,而不是我使用的'12'。 –