我遇到Nodejs和我的js代码问题。
当我在控制台服务器中运行Nodejs时没有显示任何问题,但是我一直在Chrome控制台中收到错误:
GET http://localhost/socket.io/?EIO=3&transport=polling&t=LjIvLGU 404 (Not Found)
index.html
<head>
<title>test</title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script src="http://localhost:3000/socket.io/socket.io.js"></script>
</head>
的script.js
var express = require('express');
var app = express();
var server = require('http').Server(app);
var io = require('socket.io').listen(server);
users = [];
connections = [];
server.listen(process.env.PORT || 3000);
console.log("server up");
app.get('/', function (req, res) {
res.sendFile(__dirname + '/index.php');
});
io.sockets.on('connection', function (socket) {
socket.on('subscribe', function (data) {
socket.join(data.room);
});
socket.on('arriv', function (data) {
console.log(data);
io.sockets.in('invitor').emit('send message',data);
});
socket.on('unsubscribe', function (data) {
socket.leave(data.room);
});
});
user.js的
$(function () {
var cid = $.session.get('company');
console.log(cid);
var socket = io.connect();
socket.emit("subscribe", {room: "invitor"});
socket.on("send message", function (data){
$('#info').append("" + data.gid + "</br>");
});
$(document).on('click', '.123', function () {
var gid = $(this).attr('id');
socket.emit('arriv', {gid: gid});
});
});
答案 0 :(得分:1)
您似乎正在尝试通过localhost在没有端口3000的情况下将您的套接字连接到其他地方。如果我测试您的代码片段,一切正常。您的错误消息显示我缺少端口3000 m*2
。
如果您将io.connect更改为" GET http://localhost/socket.io/?EIO=3&transport=polling&t=LjIvLGU 404 (Not Found)"
答案 1 :(得分:1)
经过大量搜索后,此方法有效:
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io('http://localhost:3000/');
</script>
答案 2 :(得分:0)
&#34;获取http://localhost/socket.io/?EIO=3&transport=polling&t=LjIvLGU 404(未找到)&#34;意味着你有socket.io没有收听你想要的服务器。我的错误是我实例化了错误的服务器对象。
在app.js文件中
var server = app.listen(config.dev.port, () => {
console.log("Listening ..");
});
var io = require('socket.io').listen(server);