繁体   English   中英

通过 WAMP 服务器使 Socket.IO 从本地主机工作

[英]Making Socket.IO work from localhost through WAMP Server

我对使用 websocket 很陌生。 虽然我作为专业人士在编码方面有很多经验,但我从来没有必要使用套接字来获取实时更新信息。

我了解 PHP、MySQL、HTML、CSS 和 JS(或 jQuery)。

我的项目已经在 PHP 和 MySQL 中启动,但我需要添加一些“实时”部分。 websocket 应用程序的目标是检查 MySQL 数据库中表中的任何更改,并在适用时通知必要的客户端。 我不想经常“刷新”页面,因为在我看来这是一种草率的做事。

现在,我已经能够遵循 Socket.IO 的几个教程,并且我在官方网站上的聊天示例工作正常。 (使用 Express、Socket.IO 和 Node.JS)

现在的问题是我想将它集成到我的主网站中,所以我猜我应该能够从我的主网站调用它,但它不起作用。

在寻找解决方案数小时后,我听说层次结构很重要,所以这里是我的:

/www/
/www/Index.php
/www/LiveUpdate/
/www/LiveUpdate/index.js

所以如果我理解正确的话,index.js 应该是我的应用服务器,而 index.php 是我的网站。

现在一切都是默认的,所以我通过http://localhost/访问网站。 我在http://localhost:3000/访问教程一 (/LiveUpdate/Index.html)。

教程之一工作得很好,但我无法在本地主机中连接。 在过去的几个小时里,我尝试了很多东西,但 Vivaldi (Chrome) 总是返回这个:

POST http://localhost/LiveUpdate/socket.io/?EIO=3&transport=polling&t=M6iMHf6 404 (Not Found)

在我的 index.php 中,我有:(重要代码的精简版)

<script src="/LiveUpdate/socket.io/socket.io.js"></script>
<script>
    var socket = io('http://localhost/:3000', {path: "/LiveUpdate/socket.io"});
</script>

在 index.js 中:

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);

//app.get('/', function(req, res){
//  res.sendFile(__dirname + '/index.html');
//});

io.on('connection', function(socket){
  console.log('a user connected');
});

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

我很感激任何帮助。 此致,

  1. 你的 Socket.IO JavaScript 将在 :3000 端口

    <script src="http://localhost:3000/socket.io/socket.io.js"></script>
  2. 还要确保您的服务器正在运行。 你可以永远使用https://github.com/foreverjs/forever

永远开始/path/index.js

它像守护进程一样工作

编辑:


对于完整的工作 index.js:

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

在您的网页内:

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM