【问题标题】:node.js and socket.io code not workingnode.js 和 socket.io 代码不起作用
【发布时间】:2014-04-28 10:13:26
【问题描述】:

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

服务器端

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 );
});

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

我没有收到错误消息,但没有广播消息。 任何人都可以帮助我解决这个问题。 任何其他可以帮助我的事情。

【问题讨论】:

  • 'message' 是一个保留的事件名称,因此请尝试使用下面在回答中建议的其他名称
  • 添加新客户端时,控制台会显示“新客户端”,但控制台不会显示任何用户消息
  • 我更改了活动名称,但仍然无法正常工作
  • 这意味着错误在你的客户端代码上,因为'message'事件没有被触发
  • 你能建议任何在客户端可能出现的错误

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


【解决方案1】:

编辑:以下是错误的!!!

尝试将您的活动称为“消息”以外的其他名称。 on('message') 处理程序只会在另一端的 socket.send() 上调用。如果你想让你的 socket.emit() 工作,你需要使用一个非保留的事件名称。

参考:https://github.com/LearnBoost/socket.io/wiki/Exposed-events

【讨论】:

  • 在将事件名称从消息更改为消息时,它不起作用
  • 我实际测试了它,结果证明 emit('message') 会触发 on('message') 就好了。我尝试了您的代码(至少是 socket.io 部分),它似乎按预期工作,不知道可能出了什么问题。你确定在客户端调用 socket.emit('message') 吗?
  • 有没有其他方法可以从客户端发送消息
  • 我不确定天气发射在客户端是否正常工作,因为我没有在服务器端获取任何数据,你能建议其他套接字方法或事件吗
【解决方案2】:

你不需要 ajax 来显示东西。要发射东西,请使用 io.emit。它向所有用户发出。并将客户端代码更改为:

socket.on('message', function(data){
   $('#messages').append('<b>'+ data.name + '</b>:<b>' + data.message + '</b>');

【讨论】:

  • 如果您愿意,我可以向您发送一个代码,该代码会在新用户连接时显示。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2014-01-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-03-25
  • 2014-12-10
相关资源
最近更新 更多