Почему видеочат не работает на веб-сокетах? - PullRequest
0 голосов
/ 08 июня 2019

Я работаю над потоковым проектом видеочата на WebSockets. Это работает правильно в localhost. Но когда я подключаю несколько устройств с сервера, я получаю сообщение об ошибке: "websocket.js: 7 Соединение WebSocket с 'wss: //tensy.org/sockjs-node/075/yxzmuhgj/websocket' не удалось: ошибка во время рукопожатия WebSocket: непредвиденный код ответа: 400 WebSocketBrowserDriver @ websocket.js: 7 "

Я использую NGINX. Возможно проблема в этом. Но вебсокеты соединяют p2p.

import React from "react";
import openSocket from 'socket.io-client';
import {server, client} from '../../params'
import $ from 'jquery';


class Space extends React.Component {
    constructor (props) {
                super(props)
                this.state = {
                        responce: []
                }
        }

        componentWillMount() {
                let _position = document.location.pathname.split('/').pop();
        console.log(_position);

        // WebRTC
        let namespace = 'space';
        const socket = openSocket('https://tensy.org/' + namespace);
        const peer = new RTCPeerConnection();

        let yourDescription;
        let otherDescription;
        let yourCandidate;
        let newCandidate;
        let candidatee;

        function addcandidate(data) {
                console.log('Candidate', data);

                setTimeout(function() {
                        if (candidatee) {
                                console.log('!', candidatee);
                                peer.addIceCandidate(JSON.parse(candidatee));
                        } else {
                                addcandidate(candidatee);
                        }
                }, 100);
       //client
        if(_position === 'student') {
            peer.onicecandidate = e => {
                if(e.candidate) {
                        yourCandidate = e.candidate;
                        console.log('cand1', yourCandidate);
                        socket.emit('cand1', {description: JSON.stringify(yourCandidate)});
                }
            }

            navigator.mediaDevices.getUserMedia({ video:true })
            .then(stream => {
                document.getElementById("local").srcObject = stream;
                peer.addStream(stream);
                return peer.createOffer();
            })
            .then(offer => {
                peer.setLocalDescription(new RTCSessionDescription(offer));
                yourDescription = peer.localDescription;
                socket.emit('call', {description: JSON.stringify(yourDescription)});
            })

            peer.ontrack = e => {
                document.getElementById("remote").srcObject = e.streams[0];
            }

            $(document).ready(function() {
                socket.on('answer', function(mes) {
                        console.log('Client 1', mes);

                        peer.setRemoteDescription(JSON.parse(mes['description']))
                        .then(() => addcandidate(candidatee))
                });

                socket.on('cand2', function(mes) {
                        console.log('Client cand 1', mes);

                        candidatee = mes['description'];
                });
            });
      } else {
           //candidate
            peer.onicecandidate = e => {
                if(e.candidate) {
                        console.log('cand2', yourCandidate);
                        yourCandidate = e.candidate;
                        socket.emit('cand2', {description: JSON.stringify(yourCandidate)});
                }
            }

            $(document).ready(function() {
                socket.on('call', function(mes) {
                        console.log('Client 2', mes);

                        navigator.mediaDevices.getUserMedia({ video:true })
                        .then(stream => {
                                document.getElementById("local").srcObject = stream;
                                peer.addStream(stream);
                                peer.setRemoteDescription(JSON.parse(mes['description']));
                        })
                        .then(() => addcandidate(candidatee)) // console.log('!!!', candidatee); addcandidate(candidatee);
                        .then(() => peer.createAnswer())
                        .then(answer => {
                                peer.setLocalDescription(new RTCSessionDescription(answer));
                                yourDescription = peer.localDescription;
                                socket.emit('answer', {description: JSON.stringify(yourDescription)});
                        })

                        peer.ontrack = e => {
                                document.getElementById("remote").srcObject = e.streams[0];
                        }

                });

                socket.on('cand1', function(mes) {
                        console.log('Client cand 2', mes);

                        candidatee = mes['description'];
                });
            });
        }
        }
    render() {
       return (
            <div id="space">
                <div className="video-control">
                    <div className="icon">
                        <i className="fas fa-sign-out-alt"></i>
                    </div>
                    <div className="icon">
                        <i className="fas fa-comment"></i>
                    </div>
                    <div className="icon">
                        <i className="fas fa-redo"></i>
                    </div>
                </div>
                <div className="video-feedback">
                    <div className="icon">
                        <i className="far fa-grin-beam-sweat"></i>
                    </div>
                    <div className="icon">
                        <i className="far fa-smile"></i>
                    </div>
                    <div className="icon">
                        <i className="far fa-smile-beam"></i>
                    </div>
                    <div className="icon">
                        <i className="far fa-grin"></i>
                    </div>
                    <div className="icon">
                        <i className="far fa-laugh"></i>
                    </div>
                </div>
                <video id="local" autoPlay></video>
                <video id="remote" autoPlay></video>
            </div>
        );
    }
};

export default Space;
...