Socket.IO 抛出类型错误
Socket.IO throwing Type Error
我有一个简单的 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, cleanup })
。通常一个人会关闭套接字并启动一个新套接字,或者在发生这种情况时结束整个过程。也许只是登录而不做任何事情会更好。查看 socket
文档。
你的实际错误:
TypeError: undefined is not a function
at Socket.<anonymous> (/root/ChatServer/index.js:109:15)
我猜你是 index.js
的作者。 我需要知道第 109 行的内容。请post将此作为评论,我可以进一步提供帮助。如果你告诉我你的 console.log
行是否有效,以及它们的输出是什么,它也可能会有所帮助。
我有一个简单的 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, cleanup })
。通常一个人会关闭套接字并启动一个新套接字,或者在发生这种情况时结束整个过程。也许只是登录而不做任何事情会更好。查看 socket
文档。
你的实际错误:
TypeError: undefined is not a function
at Socket.<anonymous> (/root/ChatServer/index.js:109:15)
我猜你是 index.js
的作者。 我需要知道第 109 行的内容。请post将此作为评论,我可以进一步提供帮助。如果你告诉我你的 console.log
行是否有效,以及它们的输出是什么,它也可能会有所帮助。