javascript - GET http ://js:port/socket. io/1/404 未找到

标签 javascript html node.js socket.io

Socket.io 连接有问题。

这是我的服务器代码:

function chatserver(){

var express = require('express'),

app = express(),

server = require('http').createServer(app).listen(app.get('port'),function(){

        console.log('Express server listening on port '+ app.get('port'));
    });
var io = require('socket.io').listen(server),
    users = {};

io.sockets.on('connection', function(socket){
    socket.on('new user', function(data, callback){
        if (data in users){
            callback(false);
        } else{
            callback(true);
            socket.nickname = data;
            users[socket.nickname] = socket;
            updateNicknames();
        }
    });

    function updateNicknames(){
        io.sockets.emit('usernames', Object.keys(users));
    }

    socket.on('send message', function(data, callback){
        var msg = data.trim();
        console.log('after trimming message is: ' + msg);
        if(msg.substr(0,3) === '/w '){
            msg = msg.substr(3);
            var ind = msg.indexOf(' ');
            if(ind !== -1){
                var name = msg.substring(0, ind);
                var msg = msg.substring(ind + 1);
                if(name in users){
                    users[name].emit('whisper', {msg: msg, nick: socket.nickname});
                    console.log('message sent is: ' + msg);
                    console.log('Whisper!');
                } else{
                    callback('Error!  Enter a valid user.');
                }
            } else{
                callback('Error!  Please enter a message for your whisper.');
            }
        } else{
            io.sockets.emit('new message', {msg: msg, nick: socket.nickname});
        }
    });

    socket.on('disconnect', function(data){
        if(!socket.nickname) return;
        delete users[socket.nickname];
        updateNicknames();
    });
});
}

我的 HTML 脚本代码:

jQuery(function($){

        var socket = io.connect('js/node_modules/socket.io/node_modules/socket.io-client/dist/socket.io.js');

        var $nickForm = $('#setNick');
        var $nickError = $('#nickError');
        var $nickBox = $('#nickname');
        var $users = $('#users');
        var $messageForm = $('#send-message');
        var $messageBox = $('#message');
        var $chat = $('#chat');

        $nickForm.submit(function(e){
            e.preventDefault();
            socket.emit('new user', $nickBox.val(), function(data){
                if(data){
                    $('#nickWrap').hide();
                    $('#contentWrap').show();
                } else{
                    $nickError.html('That username is already taken!  Try again.');
                }
            });
            $nickBox.val('');
        });

        socket.on('usernames', function(data){
            var html = '';
            for(i=0; i < data.length; i++){
                html += data[i] + '<br/>'
            }
            $users.html(html);
        });

        $messageForm.submit(function(e){
            e.preventDefault();
            socket.emit('send message', $messageBox.val(), function(data){
                $chat.append('<span class="error">' + data + "</span><br/>");
            });
            $messageBox.val('');
        });

        socket.on('new message', function(data){
            $chat.append('<span class="msg"><b>' + data.nick + ': </b>' + data.msg + "</span><br/>");
        });

        socket.on('whisper', function(data){
            $chat.append('<span class="whisper"><b>' + data.nick + ': </b>' + data.msg + "</span><br/>");
        });
    });

当我第一次加载网站时,一切正常。但是只要我点击聊天框,在 inspect elements/console 中我就会看到 "GET http://'js':5001/socket.io/1/?.." 错误出现.请指教。

最佳答案

在服务器代码中,改变这个:

server = require('http').createServer(app).listen(port),

io = require('socket.io').listen(server),

var server = http.createServer(app).listen(app.get('port'), function(){
  console.log('Express server listening on port ' + app.get('port'));
});

var io = require('socket.io').listen(server);

如果你在 http 服务器而不是 express.io 服务器,使用这个:

app.listen(app.get('port'), function(){
   console.log("Express server listening on port " + app.get('port'));
});

关于javascript - GET http ://js:port/socket. io/1/404 未找到,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20821388/

相关文章:

java - 如何将网页中的小程序包含在不同的目录中?

node.js - vue-cli-service : not found proplem on heroku? 如何解决

javascript - 幻影 Node 不传递 page.evaluate 函数的返回值

javascript - 如何在 javascript 中使用 laravel 响应 json

javascript - 来自 ember 数据存储的 ember map 对象

html - 如何使用:nth-child pseudo-class to change color of tiles on odd rows

允许多项选择的 HTML 单选按钮

node.js - 事件.js :180 throw er;//Unhandled 'error' event ^

javascript - gamepad api 和 hid api 有多少不同之处

javascript - 用于提取网页内容的 Node.Js 模块?