Javascript 无法理解为什么我的webrtc应用程序中没有多个对等点

Javascript 无法理解为什么我的webrtc应用程序中没有多个对等点,javascript,sockets,webrtc,peer,Javascript,Sockets,Webrtc,Peer,我不明白为什么当第三个对等点连接时,它会向第三个对等点抛出此错误。我认为这可能是因为连接混淆了,因为当第三方连接时,他会同时收到两个报价 我不知道我该不该排队之类的。虽然我不确定这是问题所在。我现在要试试,但如果有人能看出我做错了什么,请告诉我。 无法读取未定义的属性“setRemoteDescription” componentDidMount() { setUserMedia(); this.socket.emit('createOrJoin', this.props.ses

我不明白为什么当第三个对等点连接时,它会向第三个对等点抛出此错误。我认为这可能是因为连接混淆了,因为当第三方连接时,他会同时收到两个报价 我不知道我该不该排队之类的。虽然我不确定这是问题所在。我现在要试试,但如果有人能看出我做错了什么,请告诉我。 无法读取未定义的属性“setRemoteDescription”

componentDidMount() {
    setUserMedia();
    this.socket.emit('createOrJoin', this.props.session);
    this.socket.on('signal', (data, remoteId) => {
        switch (data.type) {
            case 'newJoin':
            console.log('joined')
                this.createPeerRtcAndStream(remoteId, (rtc) => {
                    this.createOffer(rtc, (offer) => this.socket.emit('signal', offer));
                    this.remoteClients++;
                });
                break;
            case 'offer':
                this.remoteClients++;
                this.createPeerRtcAndStream(remoteId, (rtc) => {                
                        rtc.setRemoteDescription(new RTCSessionDescription(data), () => {
                            this.createAnswer(rtc, (answer) => this.socket.emit('signal', answer));
                        });                                 
                });
                break;
            case 'answer':          
                    this.rtcs[remoteId].setRemoteDescription(new RTCSessionDescription(data));
                break;
            case 'candidate':
                let hisCandidate = new RTCIceCandidate({
                    sdpMLineIndex: data.label,
                    candidate: data.candidate
                });
                if (this.rtcs[remoteId] !== undefined && this.rtcs[remoteId].remoteDescription.type) {
                    this.rtcs[remoteId].addIceCandidate(hisCandidate);
                }
                break;
            case 'clientLeft':
                this.handleLeavingClient(remoteId);
                break;
            default:
                this.socket.emit('signal', { type: 'failedConnection' });
        }
    });
}


console.log('CLIENT DESC', session);
        if(session.creatingSession===false){
            if(rooms[session.sessionKey]){
                reciever = socket.id;
                socket.join(session.sessionKey);
        rooms[session.sessionKey].clients.push(socket.id); 
                socket.in(session.sessionKey).emit('signal',{type:'newJoin'}, socket.id);
            }               
        } else {    
            if(!rooms[session.sessionKey]){
                socket.join(session.sessionKey);    
                msgs[session.sessionKey] = [];        
                rooms[session.sessionKey] = {};
                rooms[session.sessionKey].clients = [];
            }               
    rooms[session.sessionKey].name = session.room;
    rooms[session.sessionKey].clients.push(socket.id);
    console.log('CREATED SESSION');
            redClient.hset('rooms', session.sessionKey, JSON.stringify(session)) 
        }
        socket.on('signal', (data) => {
            switch (data.type){
                case 'offer':
                    console.log('initiator  recieved');
                    sender = socket.id
                    io.to(reciever).emit('signal', data, socket.id);    
                 break;
             case 'answer':
                 console.log('answer recieved');            
                 io.to(sender).emit('signal', data, socket.id); 
                 break;
             case 'candidate':
                 console.log('Recieved candidate'); 
                 sender = socket.id;     
                 if(socket.io==reciever){
                    io.to(sender).emit('signal', data, socket.id);  
                 } else {
                    io.to(reciever).emit('signal', data, socket.id);    
                 }               
                 break;
             case 'failedConnection':
                 console.log('FAILED CONNECTION')
             default :
                 console.log('NO CASE EXECUTED')    
            } 

     });