Socket.IO抛出类型错误

时间:2015-03-03 00:51:43

标签: mysql node.js socket.io bcrypt

我有一个简单的NodeJS服务器,它使用bcrypt,mysql和socket.IO,它可以作为mysql数据库和聊天服务器的网关。此服务器使用Socket.IO客户端连接到客户端,并使用Socket.IO事件将请求发送到服务器。但是,注册事件会抛出Type Error : undefined is not a function。我检查了所有功能,但它们存在,所以我不知道发生了什么。这是我处理注册事件的代码:

socket.on('registration request', function(msg,err) {
        var split = msg.toString().split(":§:");
        var userName = split[0];
        var password = split[1];
        var email = split[2];

        console.log("Registration request : " + userName + " <===> " + email); //<====== Prints this to the console then crashes and returns the message below
        if(err){
            console.log("Socket Error !!\n" + err);
        }
        if (pattern.test(userName) && emailRegex.test(email)) {
            console.log("Data is valid. Coding password");
            password = bcrypt.hashSync(password.toString(), 2);
            console.log("Querying DB");
            DBConnection.query(
                    "INSERT INTO users (user_name,user_password,user_email) VALUES (\""
                            + userName + "\" , \"" + password + "\" , \""
                            + email + "\");", function(error, rows) {
                        if (error) {
                            console.log("Something went wrong in registering " + userName);
                            sIO.sockets.socket(socket.id).emit('registration response', "<ERROR>");
                        } else if (rows.length > 1) {
                            console.log("Registration of " + userName + " succeded");
                            sIO.sockets.socket(socket.id).emit('registration response', "<SUCCESS>");
                        } else {
                            console.log("Registration of " + userName + "denied")
                            sIO.sockets.socket(socket.id).emit('registration response', "<DENIED>");
                        }
                    });
        } else {
            socket.emit('registration response', "<DENIED>");
        }
    });

以下是错误消息:

Missing error handler on `socket`.
TypeError: undefined is not a function
    at Socket.<anonymous> (/root/ChatServer/index.js:109:15)
    at Socket.emit (events.js:107:17)
    at Socket.onevent (/root/ChatServer/node_modules/socket.io/lib/socket.js:330:8)
    at Socket.onpacket (/root/ChatServer/node_modules/socket.io/lib/socket.js:290:12)
    at Client.ondecoded (/root/ChatServer/node_modules/socket.io/lib/client.js:193:14)
    at Decoder.Emitter.emit (/root/ChatServer/node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/index.js:134:20)
    at Decoder.add (/root/ChatServer/node_modules/socket.io/node_modules/socket.io-parser/index.js:247:12)
    at Client.ondata (/root/ChatServer/node_modules/socket.io/lib/client.js:175:18)
    at Socket.emit (events.js:107:17)
    at Socket.onPacket (/root/ChatServer/node_modules/socket.io/node_modules/engine.io/lib/socket.js:99:14)

我无法找到错误。你的帮助会非常渺茫。

1 个答案:

答案 0 :(得分:5)

我对socket.io一无所知。所以这就是......

Missing error handler on `socket`.

我认为这是一个警告(意味着它没有破坏任何东西,让你知道可能的错误编码习惯),你没有添加socket.on('error', function (err) { console.error(err.stack); // TODO, cleanup })。通常会关闭套接字并启动一个新套接字,或者在发生类似这样的事情时结束整个过程。也许最好只记录并不做任何事情。查看socket文档。

您的实际错误:

TypeError: undefined is not a function
    at Socket.<anonymous> (/root/ChatServer/index.js:109:15)

我猜你是index.js的作者。 我需要知道第109行的内容。请将此内容发布为评论,我可以进一步提供帮助。如果你告诉我你的console.log行是否有效,以及它们的输出是什么,也可能有所帮助。