背景:osgi使用要使用upnp设备包括搜索和自己建立upnp设备服务,需要使用felix的UPnP Base Driver的bundle;
这个bundle的是在cybergarage的库上把upnp和osgi的框架对接并封装起来,这样上层只需要继承少量的接口类即可建立起upnp的设备服务。
问题:
pc模拟环境下测试没有问题,但是放到智能路由上出现问题,log中看到的exception为“ Network is unreachable”;
解决:
到felix官网下载upnp base driver的源码和cybergararage的源码组装成工程,然后加log定位到是在HTTPMUSocket.java
public boolean send(String msg, String bindAddr, int bindPort)
{
try {
MulticastSocket msock;
if ((bindAddr) != null && (0 < bindPort)) {
msock = new MulticastSocket(null);
msock.bind(new InetSocketAddress(bindAddr, bindPort));
}else{
msock = new MulticastSocket();
}
DatagramPacket dgmPacket = new DatagramPacket(msg.getBytes(), msg.length(), ssdpMultiGroup);
// Thnaks for Theo Beisch (11/09/04)
msock.setTimeToLive(UPnP.getTimeToLive());
msock.send(dgmPacket);
msock.close();
}
catch (Exception e) {
Debug.warning(e);
return false;
}
return true;
}
在
msock.send(dgmPacket)时发生异常。回到前面调用的方法传入的参数
bindAddr:null,bindPort为-1;因此代码应该走到else的分支中,而在路由中会有多个网段前面new
MulticastSocket没有指定ip和端口,添加
msock.setNetworkInterface(ssdpMultiIf);
就能正常使用,但是在pc上多个网段也是可以正常使用的。可能是路由上的java底层跟pc不同的。