Php 使用Node js调用socket.io函数

Php 使用Node js调用socket.io函数,php,javascript,mysql,node.js,sockets,Php,Javascript,Mysql,Node.js,Sockets,在我的nodeClient.js中,我有一个函数 socket.emit( 'message', { name: nameVal, message: msg } ); 及 任何人都可以帮我。 提前谢谢 Nodejs实时更新div的内容。您不必加载页面。如果您只使用php,则需要刷新页面以查看更改。任何人,请询问我是否需要更清楚的信息,我将提供。问题具体在哪里。就我所知,您的代码工作正常。是的,我同意@Krasimir,只要您从节点服务器向从服务器接收emit()的客户端发送,您的代码应该工作正

在我的nodeClient.js中,我有一个函数

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

任何人都可以帮我。
提前谢谢

Nodejs实时更新div的内容。您不必加载页面。如果您只使用php,则需要刷新页面以查看更改。

任何人,请询问我是否需要更清楚的信息,我将提供。问题具体在哪里。就我所知,您的代码工作正常。是的,我同意@Krasimir,只要您从节点服务器向从服务器接收
emit()
的客户端发送,您的代码应该工作正常。是的,我的代码工作正常。但是,我不觉得有和没有节点js的输出有什么不同。你能解释一下node js在这里做什么吗?你说过“内容会自动更新,而不会刷新页面”。但是,这不是在这里发生的。在我刷新页面之前,页面中的内容不会更新。这是因为我问了这个问题,有一个nodejs服务器应该通过套接字向客户端发送消息。这是真的吗?你可以发布nodejs脚本的代码吗?我只是在问题中添加了我的nodeClient.js和nodeServer.js文件,请检查并让我知道。我应该问你是如何实际测试的。据我所知,您正在本地主机上运行所有操作。您应该在浏览器中打开多个选项卡,然后尝试发送消息。代码看起来不错。我建议检查运行nodejs部分的控制台和浏览器的控制台,看看是否有任何错误。此外,您还向客户端发送了两次消息。您可以删除io.sockets.emit或client.broadcast.emit。第二个将消息发送到每个套接字,但位于客户端后面的套接字除外。只有在刷新页面后,该消息才会显示在浏览器上。我对//client.broadcast.emit('message',{name:data.name,message:data.message})进行了注释。仍然面临这个问题,我也没有看到控制台中有任何错误。
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 );
});
<ul id="messages">
    <?php 
        $query = $pdo->prepare( 'SELECT * FROM message ORDER BY msgid DESC' );
        $query->execute();

        $messages = $query->fetchAll( PDO::FETCH_OBJ );
        foreach( $messages as $message ):
    ?>
            <li> <strong><?php echo $message->name; ?></strong> : <?php echo $message->message; ?> </li>
        <?php endforeach; ?>
</ul>
var socket = io.connect( 'http://localhost:8080' );

$( "#messageForm" ).submit( function() {
var nameVal = $( "#nameInput" ).val();
var msg = $( "#messageInput" ).val();
//alert(msg);
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 );
});
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 } );
        io.sockets.emit( 'message', { name: data.name, message: data.message } );
    });
});

server.listen( 8080 );