node服务端解决socket.io跨域问题(Access to XMLHttpRequest at ‘http://localhost/socket.io/?EIO=4)

在这里插入图片描述
原先代码:

var app = require('http').createServer(handler)
var socketio = require('socket.io')
var io = socketio(app)
var fs = require('fs');
app.listen(80)
//处理web服务器正常的请求
function handler(req,res) {
    fs.readFile(__dirname + '/index.html',
        function (err, data) {
            if(err){
                res.writeHead(500);
                return res.end('Error loading index.html')
            }

            res.writeHead(200);
            res.end(data);
        }
    )
}
//实时通讯的连接
io.on("connection",function(socket){
    //客户端发送过来的数据
    socket.emit('news',{hello:'world'});
    //监听客户端发送的内容
    socket.on('my other event',function (data) {
        console.log(data)
    })
})

改完的代码:


                
  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
Access to XMLHttpRequest at 'http://39.98.175.93:9099/index/menu' from origin 'http://example.com' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. 这个错误是由于浏览器的同源策略(Same-Origin Policy)所引起的。同源策略是浏览器的一种安全机制,限制了通过JavaScript发起的跨域请求。 在这个错误,浏览器检测到你的代码正在尝试从一个源(origin)访问另一个源的资源。在默认情况下,浏览器阻止了这种跨域请求,除非服务器在响应包含了适当的CORS头部。 为了解决这个问题,你需要在目标服务器上配置CORS头部,使其允许来自'http://example.com'的跨域请求。具体的配置方式和步骤取决于你使用的服务器和框架。 一种常见的解决方法是在服务器端设置响应头部,添加'Access-Control-Allow-Origin'字段,并将其值设为允许跨域请求的源的地址(例如'http://example.com')。这样浏览器就会允许来自该源的请求访问服务器资源了。 另外,你也可以使用代理服务器来绕过同源策略的限制。通过将跨域请求发送到代理服务器,再由代理服务器转发请求给目标服务器,这样就可以在不修改目标服务器配置的情况下实现跨域请求。 总结起来,要解决这个问题,你可以通过配置目标服务器的CORS头部,或者使用代理服务器来实现跨域请求。具体的实施方法和步骤会根据你的服务器和框架而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值