今天在写subscribe的事件时,发现nodejs端总是上报callback不是function,在调用callback时程序崩溃,一直耽误了很长时间。
nodejs的服务端的代码是
socket.on('subscribe', function (options, sdp, callback) {
后来测试发现,原来是ios端发送的subscribe事件携带的参数只有options,所以sdp的赋值就成了callback的,而callback就是undefine了
现在可以想象下这个callback是怎么来了,不是从客户端传递过来的是,那应该就是websocket服务端自己给加上了,那应该是个什么内容了,可以看看下面红色内容的部分,应该就是发送type为ack的事件给客户端,args就是服务端调用callback的代码的部分,比如
callback('error', 'Token does not exist'); 后面的两个字符串就是arguments
Subscribing: { streamId: '437126123346388350', browser: 'chrome-stable' } sdp: { sdp: 'sdp' } callback: function ack() {
self.log.debug('sending data ack packet');
socket.packet({
type: 'ack'
, args: util.toArray(arguments)
, ackId: packet.id
});
}