因此,首先,我将我的项目放在GitHub上,如果您想访问完整的代码:https://github.com/jdutheil/nodePHP
这是一个非常简单的示例项目:网络聊天.你只需要一个作者和一条信息,当你按下send时,它就会保存在mysql数据库中.这样做的目的是发送实时更新,并进行真正的对话我们将使用nodeJS.
我不会谈论PHP代码,它在这里非常简单且不有趣;我想向您展示的是如何集成您的NodeJS代码.
我使用express和Socket.IO,所以一定要用npm安装这些模块.然后,我们创建一个简单的nodeJS服务器:
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 );
io.sockets.emit( 'message', { name: data.name, message: data.message } );
});
});
server.listen( 8080 );
我们在连接新用户时注册了事件回调;每次收到消息(代表聊天消息)时,我们都会将其广播给每个连接的用户.现在,棘手的部分是:客户端!这是我花费了大部分时间的部分,因为我不知道包含哪个脚本才能在没有nodeServer的情况下运行Socket.IO代码(因为客户端页面将由Apache提供服务).
但是一切都已经完成了;当您使用NPM安装Socket.IO模块时,在/node_modules/socket.io/node_modules/socket.io-client/dist/socket.io.js
中有一个脚本可用;在我的例子中,我们将在PHP页面中包含这个脚本:
<script src="js/node_modules/socket.io/node_modules/socket.io-client/dist/socket.io.js"></script>
<script src="js/nodeClient.js"></script>
最后,我的顾客.js,我们只需连接到 node 服务器,等待事件更新页面即可
var socket = io.connect( 'http://localhost:8080' );
$( "#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 );
});
我会尽快更新和改进我的代码,但我认为它已经对所有很酷的东西开放了!我真的很愿意就这件事征求意见和 comments ,这是做这件事的好方法吗??
希望这能帮助一些人!