为了账号安全,请及时绑定邮箱和手机立即绑定

Socket IO 和 Express Cross origin 错误或控制台中未找到 404 错误

Socket IO 和 Express Cross origin 错误或控制台中未找到 404 错误

一只甜甜圈 2023-12-14 16:25:17
尽管运行 cors 库,但我还是遇到了跨源标头错误,或者只是在控制台中轮询时未找到 404。项目结构如下所示我的目标是在每个视图上都有小聊天小部件。我会将其作为 EJS 部分包含到其他视图中。我不确定我出了什么问题,我尝试在端口 5000 上运行 Express,在 8080 或 3000 上运行 Socket IO,所有不同的组合都没有产生任何好处。前端部分EJS看起来像这样<ul id="messages"></ul><form action="/" method="POST" id="chatForm"><input id="txt" autocomplete="off" autofocus="on" oninput="isTyping()" placeholder="type your message  here..." /><button>Send</button></form>前端页面的其余部分如下所示  <head>  <script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/3.0.4/socket.io.js" integrity="sha512-aMGMvNYu8Ue4G+fHa359jcPb1u+ytAF+P2SCb+PxrjCdO3n3ZTxJ30zuH39rimUggmTwmh2u7wvQsDTHESnmfQ==" crossorigin="anonymous"></script>    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script><style> etcetc<%- include ('./partialChatWidget.ejs') %>还有JS<Script> var socket = io.connect('http://localhost:5000', { transport : ['websocket'] } );$('form').submit(function(e){    e.preventDefault();     socket.emit('chat_message', $('#txt').val());    $('#txt').val('');    return false;});socket.on('chat_message', function(msg){    $('#messages').append($('<li>').html(msg));});socket.on('is_online', function(username) {    $('#messages').append($('<li>').html(username));});var username = prompt('Please tell me your name');socket.emit('username', username);</script>那么这里出了什么问题,我需要在不同端口上有2个服务器还是2个实例,我一直认为socket IO借用了http服务器,而不是express实例。谢谢你的协助。我可能会补充说,当我尝试在 2 个不同的端口上运行时,会出现跨源错误。否则我会在控制台中找不到 404。页面以及部分和初始 JS(Jquery) 运行。
查看完整描述

3 回答

?
一只萌萌小番薯

TA贡献1795条经验 获得超7个赞

经过一番来来回回......


只需确保尽快将套接字 IO 的前端链接加载到头部即可。


并将这部分包含在前端


var socket = io.connect('http://localhost:5000', { transport : ['websocket'] } );

一定要在服务器端包含这个,这不会有什么坏处,除非你想阻止某些页面进行 CORS 访问


app.use(cors({origin: '*'})) 

接下来的 2 个步骤使一切顺利。


const app = express();

const http = require('http').Server(app);

const io = require('socket.io')(http,

{

cors: {

origin: "http://localhost:5000 {this is the port of your back end app, not for the socket IO port }",

credentials: true

}}) 

最后,确实是 2 台服务器。


const server = http.listen(8080, function() {

console.log('listening on *:8080');

});

app.listen(5000, console.log("App Running on http://localhost:5000"));

我花了一段时间,但现在一切都一劳永逸了(我希望)




查看完整回答
反对 回复 2023-12-14
?
鸿蒙传说

TA贡献1865条经验 获得超7个赞

试试这个代码


`const server = app.listen(PORT,()=>console.log(`listening on port ${PORT}`));

io = require('socket.io').listen(server);

io.on('connection', (socket) => {

console.log('a user connected');

});`


查看完整回答
反对 回复 2023-12-14
?
慕仙森

TA贡献1827条经验 获得超7个赞

app.use((req,res, next)=>{

res.setHeader('Access-Control-Allow-Origin',"http://localhost:3000");

res.setHeader('Access-Control-Allow-Headers',"*");

res.header('Access-Control-Allow-Credentials', true);

next();

});


使用此代码并安装较旧的 socket.io 版本 2.3.0


查看完整回答
反对 回复 2023-12-14
  • 3 回答
  • 0 关注
  • 59 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信