关于ajax跨域的一些解决方案

Posted skin-blue

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于ajax跨域的一些解决方案相关的知识,希望对你有一定的参考价值。

1、JSONP方式解决跨域问题

     jsonp解决跨域问题是一个比较古老的方案(实际中不推荐使用),当然,在实际项目中如果要使用JSONP,一般会使用JQ等对JSONP进行了封装的类库来进行ajax请求

     实现原理:

            JSONP之所以能够用来解决跨域方案,主要是因为 <script> 脚本拥有跨域能力,而JSONP正是利用这一点来实现。

     注意:

            基于JSONP的实现原理,所以JSONP只能是“GET”请求,不能进行较为复杂的POST和其它请求,所以遇到那种情况,就得参考下面的CORS解决跨域了(所以如今它也基本被淘汰了)

2、CORS解决跨域问题

      在Node.js后台配置(express框架)

Node.js的后台也相对来说比较简单就可以进行配置。只需用express如下配置:

app.all(‘*‘, function(req, res, next) {

   res.header("Access-Control-Allow-Origin", "*");

   res.header("Access-Control-Allow-Headers", "X-Requested-With");

  res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS");

  res.header("X-Powered-By", ‘ 3.2.1‘)

       //这段仅仅为了方便返回json而已

   res.header("Content-Type", "application/json;charset=utf-8");

  if(req.method == ‘OPTIONS‘) {

       //让options请求快速返回

       res.sendStatus(200);

   } else {

       next();

   }

});

3、代理请求方式解决接口跨域问题

注意,由于接口代理是有代价的,所以这个仅是开发过程中进行的。

与前面的方法不同,前面CORS是后端解决,而这个主要是前端对接口进行代理,也就是:

  • 前端ajax请求的是本地接口

  • 本地接口接收到请求后向实际的接口请求数据,然后再将信息返回给前端

  • 一般用node.js即可代理

关于如何实现代理,这里就不重点描述了,方法和多,也不难,基本都是基于node.js的。

以上是关于关于ajax跨域的一些解决方案的主要内容,如果未能解决你的问题,请参考以下文章

关于ajax跨域

如何解决IE8下Ajax调用时跨域的问题

关于跨域的处理的几种方法的整理

ajax跨域终极解决办法!

如何用CORS来解决JS中跨域的问题

相关前台跨域的解决方式