Отже, для початку я розміщую свій проект на github, якщо ви хочете отримати повний код: https://github.com/jdutheil/nodePHP
Це дуже простий приклад проекту: веб-чат. У вас просто є автор і повідомлення, і при натисканні надіслати його зберігається в базі даних 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 );
Ми зареєстрували зворотний виклик подій, коли підключено нового користувача; щоразу, коли ми отримуємо повідомлення (представляє повідомлення в чаті), ми передаємо його всім підключеним користувачам. Тепер, хитра частина: на стороні клієнта! Та частина, яка зайняла у мене більшу частину часу, тому що я не знав, до якого сценарію можна запустити код Socket.IO без nodeServer (адже сторінку клієнта обслуговуватиме Apache).
Але все вже зроблено; при встановленні модуля Socket.IO з npm, сценарій доступний у /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>
І закінчуючи, мій nodeClient.js, де ми просто підключаємося до сервера вузлів і чекаємо події, щоб оновити нашу сторінку. ;)
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 );
});
Я спробую якомога швидше оновити та вдосконалити свій код, але, думаю, він уже відкритий для всіх крутих речей! Я дійсно відкритий для порад та відгуків щодо цього матеріалу, чи це хороший спосіб зробити це, ..?
Сподіваюся, це може допомогти деяким людям!