2016-04-07 8 views
1

Ich verwende socket.io, um einen Chat-Raum in meiner Website zu machen, gibt es kein Problem, wenn ich es in meinem Computer ausführen, aber wenn ich es auf dem Produktionsserver ausführen, gibt socket.io.js Folgendes aus Fehler:WebSocket Handshake reagiert 400, funktioniert aber immer noch

WebSocket connection to 'ws://myWebsite.com/socket.io/?EIO=3&transport=websocket&sid=1qtzy4QRde6G-PHkAAAU' failed: Error during WebSocket handshake: Unexpected response code: 400 

I [email protected] für Server und Client bin mit

die Website auf Port hört 8080 hinter nginx mit Port 80, funktioniert alles einwandfrei mit Ausnahme der Fehlermeldung, aber der Chat-Raum ist noch funktionsfähig, das ist sehr seltsam.

Ich habe einige ähnliche Probleme auf Stack-Überlauf durchsucht, und die vorgeschlagenen Lösungen sind bereits meine nginx Einstellungen (/etc/nginx/sites-enabled/myWebsite.com):

server { 
     listen 80; 
     server_name myWebsite.com; 

     location/{ 
       proxy_pass http://127.0.0.1:8080; 
       proxy_http_version 1.1; 
       proxy_set_header Host $host; 
       proxy_set_header Upgrade $http_upgrade; 
       proxy_set_header Connection 'upgrade'; 
     } 
} 

Meteor WebSocket handshake error 400 with nginx Meteor WebSocket connection to 'ws://.../websocket' failed: Error during WebSocket handshake: Unexpected response code: 400

Obwohl immer noch der Chat-Raum arbeitet, noch ich möchte die Fehlermeldung

loswerden Für Ihre Referenz, ist unten der socket.io bezogenen Code:

// I use angular.js as the front-end framework 
function Socket (socketFactory, $rootScope) { 
    var ioSocket = io.connect(window.location.host); 
    var socket = socketFactory({ioSocket : ioSocket}); 
    return { 
     on: function (eventName, callback) { 
      socket.on(eventName, function() { 
       var args = arguments; 
       $rootScope.$apply(function() { 
        callback.apply(socket, args); 
       }); 
      }); 
     }, 
     emit: function (eventName, data, callback) { 
      socket.emit(eventName, data, function() { 
       var args = arguments; 
       $rootScope.$apply(function() { 
        if (callback) { 
         callback.apply(socket, args); 
        } 
       }); 
      }); 
     } 
    }; 
} 
Socket.$inject = ['socketFactory', '$rootScope']; 
angular.module('core').factory('Socket', Socket); 

Socket.on('new message', function (data) { ... }); 
+0

Also wie verbindet sich die Buchse? Sendet es eine zweite Anfrage? Wird sogar auf Websockets oder Backups auf xhr aufgerüstet? –

+0

Ich weiß nicht wirklich, wie das funktioniert, ich habe gerade zwei Browser-Registerkarten geöffnet, beide hatten die 400-Antwort, aber beide könnten Nachrichten voneinander erhalten – kitlee

Antwort

-1

Gerade festgestellt, dass meine Website CloudFlare verwendet, ist das Problem gelöst, seit ich den Proxy deaktiviert hatte.

Verwandte Themen