2017-04-08 13 views
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'); 
}); 

답변

0

는 DGRAM 방법의 일부와 주위 플레이 이것은 정말 잘 작동하는 것 같다 :

let dgram = require('dgram'); 

//DServer for UDP 
dserver = dgram.createSocket('udp4'); 
dserver.bind('1900');//UDP Port all UPNP messages broadcast on 
dserver.on('error', (err) => { 
    console.log('UDP Server ERROR:' + err); 
    dserver.close(); 
}); 
dserver.on('close',() => { 
    console.log('UDP Server closed'); 
}); 
dserver.on('listening',() => {//server start to listen after dserver.bind 
    console.log('UDP Server listening'); 
    dserver.setMulticastLoopback(true);//NEEDED to allow broadcast packets 
    //on the network interface, NodeJS documentation has more info. 
    dserver.setMulticastTTL(128);//This is for sending not needed for recieving 
    dserver.addMembership('239.255.255.250');//add to broadcast-IP UPNP range 

}); 
dserver.on('message', (msg, rinfo) => {//When receive message print to screen 
    console.log(msg + '\n' + rinfo); 
});