我正在尝试解析BeagleBone Black设备的IP地址,该设备与运行我的应用的Android设备位于同一网络上。我的设备的主机名是"tovremgw.local"
。如果我尝试从Windows pc命令行执行ping操作,它将成功返回IPv6地址。
使用以下代码时:
new Thread(new Runnable(){
public void run(){
Inet6Address addr = null;
try {
addr = (Inet6Address) Inet6Address.getByName("tovremgw.local");
} catch (UnknownHostException e) {
e.printStackTrace();
}
System.out.println(addr);
}
}).start();
它将返回Exception:
“ java.net.UnknownHostException:无法解析主机 “ tovremgw.local”:没有与主机名关联的地址“
我在同一台PC上的模拟器中运行该应用程序。
答案 0 :(得分:0)
根据BeagleBoard documentation
如果Beagle通过以下方式连接到局域网(LAN) 以太网或WiFi,它将利用mDNS进行广播 你的电脑。如果您的计算机支持mDNS,则应该看到 小猎犬身为beaglebone.local。非BeagleBone板将利用 备用名称。同一网络上的多个BeagleBone板将 添加后缀,例如beaglebone-2.local。
此处使用的命名服务协议为Multicast DNS,与标准DNS协议(单播)不同。由于Inet6Address仅支持标准DNS,并且也记录类型为“ A”或“ AAAA”的记录,因此无法满足您的目的。
我建议您查看支持mDNS服务发现的库,例如mndsjava
答案 1 :(得分:0)
我不知道这是否是最好的答案,但是我没有设法使用其他方法使其工作。我不知道这对有同样问题的人是否有帮助,但是我将发布我的代码只是为了说明我是如何做到的。
public String initUdpClient() throws IOException, InterruptedException {
String tovremgwip = "";
DatagramSocket s = new DatagramSocket();
byte[] buffer = new byte[2048];
DatagramPacket packet = new DatagramPacket(buffer, buffer.length);
int server_port = 5353;
InetAddress inetaddress = InetAddress.getByName("224.0.0.251");
char[] bytearray = {
0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x08, 0x74, 0x6f, 0x76,
0x72, 0x65, 0x6d, 0x67, 0x77, 0x05, 0x6c, 0x6f,
0x63, 0x61, 0x6c, 0x00, 0x00, 0x01, 0x00, 0x01
};
String messageStr = new String(bytearray);
int msg_length = messageStr.length();
byte[] message = messageStr.getBytes();
DatagramPacket p = new DatagramPacket(message, msg_length, inetaddress, server_port);
for(int i = 0; i < 3; i++){
s.send(p);
s.receive(packet);
int length = packet.getLength();
if(length > 0){
int[] temparr = new int[length];
for(int y = length - 4; y < length; y++){
tovremgwip = tovremgwip + Integer.toString(packet.getData()[y] & 0xFF);
if(y != length - 1) tovremgwip = tovremgwip + ".";
}
return tovremgwip;
}
packet.setLength(buffer.length);
TimeUnit.SECONDS.sleep(1);
}
return "";
}
在使用Wireshark对Beaglebone进行ping操作时,我设法复制了PC发送的数据包。然后获取收到的消息的最后四个字节。