繁体   English   中英

Socket.io TypeError:未定义不是函数

[英]Socket.io TypeError: undefined is not a function

我正在制作一个简单的聊天应用程序。 连接,“ 登录 ”并发送聊天消息就可以了。 但是,当我刷新页面并尝试再次登录时,出现错误;

socket上缺少错误处理程序。
TypeError:undefined不是Socket的函数。 '<'anonymous>
[。 ]在server.js:30:19

Server.js

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
var path = require('path');

var users = [];
var chat_history = [];

[...]

io.on('connection', function(socket){
    //
    // LOGIN
    ///////////////////////////
    socket.on('login', function(username) {
        if(!socket.username && username) {
            socket.emit('logged_in', 'successful');
            socket.emit('chat_history', JSON.stringify(chat_history));
            io.emit('notice', username + ' has connected.');
            socket.username = username;
            users.push(username);

            update_users();


            //
            // CHAT MESSAGE RECEIVED
            ///////////////////////////
            socket.on('chat_message', function(msg){
                var message = getTime() + ' ' + socket.username + ': ' + msg;

                update_chat_history(message);
            });


            //
            // DISCONNECT
            ///////////////////////////
            socket.on('disconnect', function () {
                io.emit('notice', socket.username + ' has left the channel.');
                console.log(socket.username + ' disconnected');

                update_users();
            });
        } else {
            socket.emit('logged_in', 'unsuccessful');
            socket.emit('notice', 'Login was unsuccessful, please refresh the page and try again.');
        }
    });


    ///////////////////////////////////////////
    //socket.on('error', function (err){
    //    console.error(err.stack);
    //});
    ///////////////////////////////////////////
});

http.listen(port, ip);

console.log('listening on ' + ip + ':' + port);



//
// Functions
///////////////////////////
function getTime() {
    var t = new Date();
    t = '[' + t.getUTCHours() + ' : ' + t.getUTCMinutes() + ']';

    return t;
}

function update_users() {
    //console.log(io.sockets.connected);
    users = [];

    for( var client in io.sockets.connected ){
        var username = io.sockets.connected[client].username;
        if(username){
            users.push(username);
        }
    }

    users = JSON.stringify(users);
    io.emit('users_online', users);
}

function update_chat_history(message_to_add){
    chat_history.push(message_to_add);

    if(chat_history.length > 20){
        chat_history.splice(0, 1);
    }
}

在socket.on('login')上,我测试了刷新页面或断开con后是否未定义套接字。
我想这与不更新连接并尝试重新连接到同一连接有关,但是我不知道如何或怎样。 在stackoverflow上找不到解决方案。 感谢帮助。

更新:布拉尔(Blaargh)这根本没有任何效果(╯°□°)╯︵┻━┻

还是一样的错误。 现在位于server.js:78:11

http://1.1m.yt/kgaZSBfUa.png

删除了所有socket.usernames并将登录更改为;

 socket.on('login', function(username) { if( username ) { // TODO what if duplicate username socket.emit('logged_in', 'successful'); socket.emit('chat_history', JSON.stringify(chat_history)); io.emit('notice', username + ' has connected.'); add_user(socket.id, username); [...] 

还更改了update_users()

 function add_user(id, username){ users.push({ 'id' : id, 'username' : username }); var json_users = JSON.stringify(users); io.emit('users_online', json_users); } function remove_user(id){ for(user in users){ if(users[user]['id'] == id){ users.splice(users[user], 1); break; } } var json_users = JSON.stringify(users); io.emit('users_online', json_users); } 


更新:2

我仍然完全不知道可能是什么问题,但是我设法设法解决了这个问题,因此现在可以解决了。

每次刷新页面时,都会删除套接字并创建一个新套接字(没有属性用户名,因为它是一个新套接字),因此您需要找到一种方法来保留用户名

对于您的情况,我建议您将用户名放入cookie中,并检查页面加载是否存在cookie“ username”,如果有,则具有值,然后更新(新)套接字

一种更高级的方法: 处理浏览器重载套接字io

希望这可以帮助 !

编辑

npm install-保存lodash

    var _ = require('lodash')
    var users = [];

    io.sockets.on('connection', function (socket) {
        socket.username ="guest"
     socket.on('login', function(username) {
            if( username) {
                socket.emit('logged_in', 'successful');
                io.emit('notice', username + ' has connected.');
                socket.username = username ;
                // users.push(username);
            add_user(socket.id, username , users);

                //
                // CHAT MESSAGE RECEIVED
                ///////////////////////////
                socket.on('chat_message', function(msg){
                    var message = date.Now() + ' ' + socket.username + ': ' + msg;

                });


                //
                // DISCONNECT
                ///////////////////////////
                socket.on('disconnect', function () {
                    io.emit('notice', socket.username + ' has left the channel.');
                    console.log(socket.username + ' disconnected');


                });
            } else {
                socket.emit('logged_in', 'unsuccessful');
                socket.emit('notice', 'Login was unsuccessful, please refresh the page and try again.');
            }
        });



        socket.emit('message', { message: 'welcome to the chat' });
        socket.on('send', function (data) {
            io.sockets.emit('message', data);
        });
    });
    console.log("Listening on port " + port);


    function add_user(id, username , users){

        var item = {
            'id' : id,
            'username' : username
        }

     var oldItem = _.find(users, {id: id});
              var index = users.indexOf(oldItem);

              if (oldItem) {
                users.splice(index, 1);
                users.unshift(item);
              } else {
                users.unshift(item);
              }





        users = JSON.stringify(users);
            console.log(users)
        io.emit('users_online', users);
    }

    function remove_user(id){
        for(user in users){
            if(users[user]['id'] == id){
                users.splice(users[user], 1);
                break;
            }
        }
        users = JSON.stringify(users);
        io.emit('users_online', users);
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM