[英]Socket.io TypeError: undefined is not a function
我正在制作一个简单的聊天应用程序。 连接,“ 登录 ”并发送聊天消息就可以了。 但是,当我刷新页面并尝试再次登录时,出现错误;
socket
上缺少错误处理程序。
TypeError:undefined不是Socket的函数。 '<'anonymous>
[。 。 。 ]在server.js:30:19
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
删除了所有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.