常见跨域解决方案总结

1.cors方案

CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing)。CORS需要浏览器和服务器同时支持。目前,所有浏览器都支持该功能,IE浏览器不能低于IE10。它允许浏览器向跨源服务器,发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制。整个CORS通信过程,都是浏览器自动完成,不需要用户参与。对于开发者来说,CORS通信与同源的AJAX通信没有差别,代码完全一样。浏览器一旦发现AJAX请求跨源,就会自动添加一些附加的头信息,有时还会多出一次附加的请求(option请求),但用户不会有感觉。因此,实现CORS通信的关键是服务器。只要服务器实现了CORS接口,就可以跨源通信

2.jsonp

  • js支持跨域
  • 请求一个js路径的文件,发起请求,在其后带一个callback(data),服务器返回文件时,将数据注入到callback中
  • 浏览器端定义一个callback函数,并打印出data,就拿到了值

3.webpack  代理

跨域是浏览器端的限制,这里由node截获http请求,由node来转发出去即可,突破浏览器跨域限制。

4.nginx

proxy_pass  转发url  实现配置即可

5.fiddler

支持正向代理和反向代理,对于在本地开发,需要登录生产或者灰度环境,并使用其数据进行本地开发时,非常有用。

6.修改浏览器配置

本地调试可以用下,并不推荐,关闭

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值