什么是js跨域,如何解决

js跨域释义:

     js跨域是指通过js在不同的域之间进行数据传输或通信,如:从www.baidu.com 页面去请求 www.google.com的资源。 域:协议、域名、端口都一致。需要跨域。

原因:

     由浏览器的同源策略造成的,是浏览器对javascript施加的安全限制。

跨域的2中情况:

     1、通常的get类型请求;

     2、put、post、delete之类的(RESTful风格)。

问题解决:

     1、代理:简单的说就是甩锅,把进行数据传输或通信的事情甩给后端,由后端作为中转。这个能解决所以跨域问题。

     2、jsonp:利用<script>、<img>、<iframe>等标签来实现跨域的一种非正式传输协议,只支持get方式。JQuery对于Ajax的跨域请求有两类解决方案,分别是JQuery的 jquery.ajax jsonp格式和jquery.getScript方式,也只支持get方式

 

      jQuery.ajax({
            type: "get",
            url: "http://10.10.163.174:1120/cases/kn/case/getCaseInfo",
            dataType: "jsonp",
            jsonp: "callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(一般默认为:callback)
            jsonpCallback:"flightHandler",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名,也可以写"?",jQuery会自动为你处理数据
            success: function(json){
                alert('success' + JSON.stringify(json));
            }
        });

 

更详细了解:https://segmentfault.com/a/1190000007232373

     3、CORS(Cross-Origin Resource Sharing):W3C中一项新的特性。

CORS:http://blog.csdn.net/besto229/article/details/78637315

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章