跨域访问
跨域
跨域是指从一个域名的网页去请求另一个域名的资源。比如从http://www.baidu.com/ 页面去请求 http://www.google.com 的资源。跨域的严格一点的定义是:只要 协议,域名,端口有任何一个的不同,就被当作是跨域。
ajax中XMLHttpRequest不能发起跨域请求
跨域请求的例子
http://www.123.com/index.html 调用 http://www.123.com/server.php (非跨域)
http://www.123.com/index.html 调用 http://www.456.com/server.php (主域名不同:123/456,跨域)
http://abc.123.com/index.html 调用 http://def.123.com/server.php (子域名不同:abc/def,跨域)
http://www.123.com:8080/index.html 调用 http://www.123.com:8081/server.php (端口不同:8080/8081,跨域)
http://www.123.com/index.html 调用 https://www.123.com/server.php (协议不同:http/https,跨域)
ajax解决跨域请求
通过设置crossDomain和xhrFields解决跨域请求(带cookie)
$("#loginBtn").click(function(){
$.ajax({
type: "get",
url: "http://192.168.43.142:8080/travelnotes/login",
data: {
"account": $("#account").val(),
"password": $("#password").val()
},
//crossDomain和xhrFields跨域请求(带cookie)
crossDomain: true,
xhrFields: {
withCredentials: true
},
datatype: "json",
success: function(data){
console.log(data);
},
error: function(){
console.log("失败");
}
});
});Java代码解决跨域请求
Options 预请求
如果ajax跨域请求设置了headers,会调用一次options请求获取服务器是否允许此域名的请求的,如果没有设置Access-Control-Allow-Headers就会报跨域错误。
Springmvc对跨域请求的解决方式
Spirngmvc 4.2以后才支持跨域请求的解决。
首先,在web.xml中增加dispatchOptionsRequest的配置
然后在相应的方法上加注解@CrossOrigin
Last updated