0
UPNP에 전송 된 브로드 캐스트 메시지를 수신하는 NodeJS 코드가 있습니다. 하나의 코드 스 니펫은 1900 포트에서 수신하고, 다른 코드는 1900 포트에서 UDP에 대해 dgram을 사용합니다. 어떤 코드도 메시지를 반환하지 않습니다. 나는 네트워크에서 트래픽이 방송되고 있음을 확인했다. 같은 시간에 두 코드를 모두 실행하지는 않습니다. 이렇게하면 포트 문제를 피할 수 있습니다. netstat -a를 사용하면 코드가 실행 중일 때 사용중인 포트를 볼 수 있습니다.UPNP 수신 대기 트래픽이 없습니다.
왜 이러한 UPNP 메시지를받지 못합니까?
//DServer for UDP
/*dserver = dgram.createSocket('udp4');
dserver.bind('1900',() => {
console.log('Listening on address:' + dserver.address());
});
dserver.on('error', (err) => {
console.log('UDP Server ERROR:' + err);
dserver.close();
});
dserver.on('close',() => {
console.log('UDP Server closed');
});
dserver.on('listening',() => {
console.log('UDP Server listening');
});
dserver.on('message', (msg, rinfo) => {
console.log(msg + '\n' + rinfo);
});*/
//TCP Server (for testing)
let dserver = net.createServer((socket) => {
socket.on('data', (data) => {
console.log("DATA:" + data.toString());
}).on('error', (err) => {
console.trace('DServer socket.on: error');
console.error(err.stack);
});
}).on('listening',() => {
console.log('DServer Listening');
}).on('connection',() => {
console.log('DServer got a connection');
}).on('close',() => {
//stays open if client closes conx
console.log('DServer Closed');
}).on('error', (err) => {
console.trace('DServer.on: error');
console.error(err.stack);
});
dserver.listen({ port: 1900 },() => {
console.log('DServer Started Listening');
});