mysql - Socket.IO 抛出类型错误

标签 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)

我找不到我的错误。非常感谢您的帮助。

最佳答案

我对 socket.io 了解不多。就这样吧……

Missing error handler on `socket`.

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

你的实际错误:

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

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

关于mysql - Socket.IO 抛出类型错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28822196/

相关文章:

python - Django:你如何阻止长查询杀死你的数据库?

MySQL - 选择不同用户的 N 随机行,其中仅包含小于或等于 X 的值

java - Spring外键无限循环

javascript - 如何使用@types/socket.io 的接口(interface)

javascript - 为什么套接字连接在 onsubmit-event 内不起作用?

php - 将函数中的 MySQL 行作为数组返回

javascript - NodeJS 需要来自未知的子文件夹

javascript - 为什么 process.__proto__ !== process.constructor.prototype ?

Mysql根据用户输入过滤查询

javascript - 通过 LAN 托管 Socket.io 服务器