Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/38.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
带有node.js的WebSocket_Node.js_Websocket - Fatal编程技术网

带有node.js的WebSocket

带有node.js的WebSocket,node.js,websocket,Node.js,Websocket,我正在尝试一个WebSocket的例子来开发一个简单的聊天 server.js: var app = require('http').createServer(handler) , io = require('socket.io').listen(app) , fs = require('fs') app.listen(8080); function handler (req, res) { fs.readFile(__dirname + '/test.html', functi

我正在尝试一个WebSocket的例子来开发一个简单的聊天

server.js

var app = require('http').createServer(handler)
, io = require('socket.io').listen(app)
, fs = require('fs')

app.listen(8080);

function handler (req, res) {
   fs.readFile(__dirname + '/test.html',
   function (err, data) {
      if (err) {
        res.writeHead(500);
        return res.end('Error loading index.html');
      }

    res.writeHead(200);
    res.end(data);
  });
}
test.html

<script src="/socket.io/socket.io.js"></script>
<script>
 var socket = io.connect('http://localhost');

 socket.on('connect', function() {
  alert('<li>Connected to the server.</li>');
 });

 socket.on('message', function(message) {
    alert(message);
 });

 socket.on('disconnect', function() {
   alert('<li>Disconnected from the server.</li>');
 });

 function sendF(){
    var message = "Test";
    socket.send(message);
    alert('Test Send');     
}

var socket=io.connect('http://localhost');
socket.on('connect',function(){
警报(“
  • 已连接到服务器。
  • ”); }); socket.on('message',函数(message){ 警报(信息); }); socket.on('disconnect',function()){ 警报(“
  • 已断开与服务器的连接。
  • ”); }); 函数sendF(){ var message=“Test”; socket.send(消息); 警报(“测试发送”); }

    test.html
    中,我还有一个简单的按钮,
    onClick
    call
    sendF

    如果我尝试,我会在连接、发送和断开连接时在浏览器上看到一个警报,如果我在控制台中签入,我会看到消息


    但我无法从服务器收到相同的消息响应,无法在浏览器中显示它!我认为('message'…对我来说不起作用!

    您的server.js缺少事件侦听器。它也缺少发送要在浏览器中显示的消息的位置

    io.sockets.on('connection', function (socket) {
      console.log('user connected');
      socket.send('hello world');
      socket.on('disconnect', function () {
        console.log('user disconnected.');
      });
      socket.on('message', function (data) {
        console.log(data);
      });
    });
    

    我没有使用socket.io的经验,但是WebSockets服务器不应该像您这样返回HTML标题和内容。您确定要创建WebSockets服务器吗?socket.io不一定创建WebSockets。socket.io找到可用的最佳协议,如长轮询,并使用它。