1

我用node.js和 socket.io做实验,它在本地运行良好。 我可以读取一个 html 文件并为多个用户管理一个交互式按钮。

所以我把它上传到Cloud9上,但我有一个错误 ENOENT 试图找到 html 文件。它在根目录中(就像在本地一样),该行是 fs.readFile('ex.html' 等...

这是打开 html 文件的测试代码,我在控制台上有enoent 错误

var http = require('http');
var fs = require('fs');

http.createServer(function(request, response) {
    response.writeHead(200, {
        'Content-Type': 'text/html'
    });
    fs.readFile('ex.html', function(err, data){
            if(err) throw err;
            response.end(data);
        });
}).listen(process.env.PORT, process.env.IP);

这是另一个显示空白页的程序(完整) ...

服务器 :

var http    =    require('http');
var fs      =   require('fs');

// Creation du serveur
var app = http.createServer(function (req, res) {
    // On lit notre fichier app.html
    fs.readFile('app.html', 'utf-8', function(error, content) {
        res.writeHead(200, {'Content-Type' : 'text/html'});
        res.end(content);
    });
});

var io = require("socket.io");
io = io.listen(app);

io.sockets.on('connection', function (socket) {

  socket.on('joue', function () {
    socket.broadcast.emit('joue2');

  }); // joue


});  // connection


app.listen(process.env.PORT, process.env.IP);

客户端(app.html):

<html><head> <title>Hello</title></head><body>


<button id="button">clic</button>
<div id="render">a</div>



<script type="text/javascript" src="/socket.io/socket.io.js"></script>
<script type="text/javascript">

var socket = io.connect();
var button = document.getElementById('button');
var render = document.getElementById('render');
button.addEventListener("click", clique, false);



       function clique() {
       socket.emit('joue');
        }

         socket.on('joue2', function () {

            if (render.innerHTML == 'a') {
                render.innerHTML = 'clic multi';
            } else {
                render.innerHTML = 'a';
            }

    });

</script></body></html>

我已经在服务器上安装了 socket.io,所有文件都在文件夹 node.js 的根目录中。我已经向 Cloud9 询问过,但他们说这对他们有用……对不起我的英语,如果我是初学者。

感谢您的帮助 :)

4

1 回答 1

0

我猜你的ex.html文件在 node.js 目录中。

尝试fs.readFile('node.js/ex.html', ...

于 2013-08-06T22:51:53.970 回答