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