WebSocket连接失败。WebSocket握手期间出错 - socketjs

9

详情:

我一直在尝试配置我的React项目,使其能够与hot loader一起工作,这样我就可以在不必重新启动服务器的情况下进行活动开发。但每次websocket尝试连接时,我都会收到连续的错误消息:

WebSocket connection to 'ws://192.168.33.10/sockjs-node/301/eo4p2zps/websocket' failed: Error during WebSocket handshake: Unexpected response code: 404。 我的直觉告诉我,这可能与我的虚拟机(vagrant)有关,它运行着Ubuntu -v 14.04.3 。除了以上记录的错误外,我还得到了以下错误:

http://192.168.33.10/sockjs-node/629/s0dz3nxv/xhr_streaming?t=1482558136743 404 (Not Found)
http://192.168.33.10/sockjs-node/629/jbjciaga/eventsource 404 (Not Found)
http://192.168.33.10/sockjs-node/iframe.html 404 (Not Found)
http://192.168.33.10/sockjs-node/629/e1x0l01e/xhr?t=1482558137388 404 (Not Found)
Warning: [react-router] Location "/sockjs-node/629/dr44jysd/htmlfile?c=_jp.ajy5ad3" did not match any routes
client?e2df:41 [WDS] Disconnected!
Uncaught SyntaxError: Unexpected token <

我也使用了以下模板:https://github.com/jpsierens/webpack-react-redux,希望能够比较我的当前配置,但是两者都看起来很合适。
配置: webpack.config.js:
'use strict';

var path = require('path');
var webpack = require('webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
    devtool: 'eval-source-map',
    entry: [
        'webpack-dev-server/client?http://0.0.0.0:80/',
        'webpack/hot/only-dev-server',
        'react-hot-loader/patch',
        path.join(__dirname, 'app/index.js')
    ],
    output: {
        path: path.join(__dirname, '/dist/'),
        filename: '[name].js',
        publicPath: '/'
    },
    plugins: [
        new HtmlWebpackPlugin({
          template: 'app/index.tpl.html',
          inject: 'body',
          filename: 'index.html'
        }),
        new webpack.optimize.OccurenceOrderPlugin(),
        new webpack.HotModuleReplacementPlugin(),
        new webpack.NoErrorsPlugin(),
        new webpack.DefinePlugin({
          'process.env.NODE_ENV': JSON.stringify('development')
        })
    ],
    eslint: {
        configFile: '.eslintrc',
        failOnWarning: false,
        failOnError: false
    },
    module: {
        preLoaders: [
            {
                test: /\.js$/,
                exclude: /node_modules/,
                loader: 'eslint'
            }
        ],
        loaders: [
            {
                test: /\.js?$/,
                exclude: /node_modules/,
                loader: 'babel'
            },
            {
                test: /\.json?$/,
                loader: 'json'
            },
            {
                test: /\.scss$/,
                loader: 'style!css!sass?modules&localIdentName=[name]---[local]---[hash:base64:5]'
            },
            { test: /\.woff(2)?(\?[a-z0-9#=&.]+)?$/, loader: 'url?limit=10000&mimetype=application/font-woff' },
            { test: /\.(ttf|eot|svg)(\?[a-z0-9#=&.]+)?$/, loader: 'file' }
        ]
    }
};

server.js

var webpack = require('webpack');
var WebpackDevServer = require('webpack-dev-server');
var config = require('./webpack.config');

new WebpackDevServer(webpack(config), {
    publicPath: config.output.publicPath,
    hot: true,
    historyApiFallback: true,
    // It suppress error shown in console, so it has to be set to false.
    quiet: false,
    // It suppress everything except error, so it has to be set to false as well
    // to see success build.
    noInfo: false,
    stats: {
      // Config for minimal console.log mess.
      assets: false,
      colors: true,
      version: false,
      hash: false,
      timings: false,
      chunks: false,
      chunkModules: false
    }
}).listen(8080, 'localhost', function (err) {
    if (err) {
        console.log(err);
    }

  console.log('Listening at localhost:8080');
});

补充

同时,您还可以查看我错误的更多图形化输出:

错误控制台输出

结论

如果您有任何建议或想法,请告诉我。如果我可以提供更多细节,请让我知道。


我在浏览器上运行MQTT客户端时遇到了类似的问题。通过重新配置端口,我解决了这个问题。有两个端口,一个用于IPv4,另一个用于IPv6。我只需要使用其中一个即可。 - Eddie
有趣的是,我认为webpack-dev-server可能被阻止了。让我看看端口配置。 - David Biga
1个回答

16

好的,我知道我即将说的话很奇怪,但这就是发生在我的身上的事情。

我假设你正在使用nginx代理,而 'Error during WebSocket handshake - socketjs'与chrome浏览器或websocket(ws)脚本无关。 它在Firefox中也同样出现了错误。 经过(真正)一段时间后,我发现'ws'脚本需要按顺序加载,并且它与代理有关。 它会以“404”方式转到,就好像没有从websocket接收到响应。

而且,我尝试设置我的nginx代理位置为:

location / {
    proxy_pass http://127.0.0.1:3000/;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "Upgrade";
    #proxy_set_header Host $host;
}

这样可以生效。将代理设置为nginx时,必须至少指定头部主机和连接。

我注释掉了proxy_set_header,因为$host变量在您的情况下可能不同。


2
这对我非常有效。我的nginx.conf几乎相同,只是我没有proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "Upgrade";。谢谢! - Joe Sadoski
1
完美地工作了,千言万语谢谢! - A cup of tea
1
我在使用Websockets和nginx时遇到了类似的问题,我认为问题可能也是代理。除了'WebSocket connection to 'ws://hostip/websocket' failed:'之外,我没有收到任何错误提示,而且我的nginx设置与你的不太一样。它有类似的设置,但它们是用于location /api和location /grafana的。但是location /只有root和try_files。你认为我需要为location /websockets设置一个设置吗? - momal
感谢Joe Sadoski。proxy_set_header Connection "Upgrade";对我很有帮助。 - Sergio Belevskij

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接