【问题标题】:socket.io not working properly for broadcast applicationsocket.io 对于广播应用程序无法正常工作
【发布时间】:2014-04-28 12:29:56
【问题描述】:

我正在使用此代码进行简单的广播。

服务器端

var socket = require( 'socket.io' );
var express = require( 'express' );
var http = require( 'http' );

var app = express();
var server = http.createServer( app );

var io = socket.listen( server );

io.sockets.on( 'connection', function( client ) {
console.log( "New client !" );

client.on( 'message', function( data ) {
    console.log( 'Message received ' + data.name + ":" + data.message );

    client.broadcast.emit( 'message', { name: data.name, message: data.message } );
    client.emit( 'message', { name: data.name, message: data.message } );
});
});

server.listen( 16558 );

对于客户端,我使用此代码发送和接收来自其他在线用户的消息 客户端

var socket = io.connect( 'http://localhost:16558' );

$( "#messageForm" ).submit( function() {
var nameVal = $( "#nameInput" ).val();
var msg = $( "#messageInput" ).val();

socket.emit( 'message', { name: nameVal, message: msg } );

// Ajax call for saving datas
$.ajax({
    url: "./ajax/insertNewMessage.php",
    type: "POST",
    data: { name: nameVal, message: msg },
    success: function(data) {

    }
});

return false;
});

socket.on( 'message', function( data ) {
    var actualContent = $( "#messages" ).html();
var newMsgContent = '<li> <strong>' + data.name + '</strong> : ' + data.message + '</li>';
var content = newMsgContent + actualContent;

$( "#messages" ).html( content );
});

socket.emit 在客户端不工作。

添加新客户端时,控制台上会显示“新客户端”,但当任何用户发送消息时,控制台上不会显示

我没有收到错误消息,但没有广播消息。 任何人都可以帮助我解决这个问题。 有没有其他我可以使用的事件或方法,因为它看起来像发出不正常工作

【问题讨论】:

  • 尝试使用这个 - socket.join("roomName"); 上面的行应该低于 console.log("New Client");
  • 另外,在广播时使用这个io.sockets.in('roomName').emit('event_name', data)这是来自https://github.com/LearnBoost/socket.io/wiki/Rooms
  • 可能是客户端问题,因为套接字似乎正在工作。也许 jquery 部分没有按预期工作。检查名称和函数调用。它实际上是在调用向服务器发送消息吗?

标签: javascript node.js sockets express socket.io


【解决方案1】:

而不是使用

socket.emit( 'message', { name: nameVal, message: msg } );

试试这个

socket.emit( 'message', nameVal, msg  );

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-09-06
    • 2012-12-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多