js跨域访问问题

1、什么是跨域访问

这里说的js跨域是指通过js在不同的域之间进行数据传输或通信,比如用ajax向一个不同的域请求数据,或者通过js获取页面中不同域的框架中(iframe)的数据。只要协议、域名、端口有任何一个不同,都被当作是不同的域。如果进行跨域访问,浏览器会报跨域访问异常

NO 'Access Control-Allow-Origin' ....
CORS:Cross-orign resource sharing跨域分享资源

总之,当前页面你发送请求时只要协议、域名、端口号有一个与当前页面不一致都属于跨域访问。

2、跨域访问的解决方法

CORS解决方案

2.1 在Controller层的处理器上解决

后端解决方式一

//解决方法一:http://localhost:9105也可设置为*,表示那个域可以进行跨域访问,但是*号不能用cookie,允许访问的域
response.setHeader("Access-Control-Allow-Origin", "http://localhost:9105");
//----如果用了cookie信息-----,必须加后面这句话,如果不用cookie可以不加这句话
response.setHeader("Access-Control-Allow-Credentials", "true");

后端解决方式二

//解决方法二:在处理器方法上加注解,allowCredentials="true",默认为false
@CrossOrigin(origins="http://localhost:9105",allowCredentials="true")

在端口号为9105的web前端也要处理,以AngularJS为例,在Service.js中添加如下内容{'withCredentials':true}

//而且客户端的请求也需要加参数{'withCredentials':true} )
$http.get('http://localhost:9107/cart/addItemToCartList.do?itemId='+?+'&num='+? ,{'withCredentials':true} ).success.....

JSOUP解决方案

2.2 JSONP

参考https://dailc.github.io/2017/03/22/ajaxCrossDomainSolution.html

原文地址:https://www.cnblogs.com/kitor/p/11291603.html