我有一个简单的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)
我无法找到错误。你的帮助会非常渺茫。
答案 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
行是否有效,以及它们的输出是什么,也可能有所帮助。