簡體   English   中英

集成node.js,socket.io和php網頁

[英]Integrating node.js, socket.io and php web page

我將把我的php網頁與node.js和socket.io集成在一起。 客戶端可以連接到node.js服務器文件,但是socket.emit函數無法從客戶端到服務器或返回。 這是我的nodeClient.js文件:

var socket = io.connect( 'http://192.168.0.10:8080/index3.php' );

$( "#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( 'new message', function( data ) {
    var actualContent = $( "#messages" ).html();
    var newMsgContent = '<li> <strong>' + data.name + '</strong> : ' + data.message + '</li>';
    var content = newMsgContent + actualContent;

    $( "#messages" ).append(newMsgContent);
});

這是nodeServer.js文件:

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( 'new message', { name: data.name, message: data.message } );
});
});

server.listen( 8080, function(){
  console.log('listening on *:8080');
});

ajax可以將數據存儲在mysql中。 每個連接的客戶端都被識別為“新客戶端!”。 但是客戶端和服務器之間沒有消息通信。 我的代碼可能是什么問題。

更正您的JSON語法,而不是在客戶端編寫:

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

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

同樣在服務器端,您實際上在json對象中寫入值名稱時錯過了雙引號

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM