首先说一下什么是跨域?
JavaScript出于安全方面的考虑,不允许跨域调用其他页面的对象。那什么是跨域呢,简单地理解就是因为JavaScript同源策略的限制,a.com域名下的js无法操作b.com或是c.a.com域名下的对象。
当协议、子域名、主域名、端口号中任意一个不相同时,都算作不同域。不同域之间相互请求资源,就算作“跨域”。
例如:http://www.abc.com/index.html 请求 http://www.efg.com/service.php。
有一点必须要注意:跨域并不是请求发不出去,请求能发出去,服务端能收到请求并正常返回结果,只是结果被浏览器拦截了。之所以会跨域,是因为受到了同源策略的限制,同源策略要求源相同才能正常进行通信,即协议、域名、端口号都完全一致。
在这之前小冷自己写了个简单的前端页面(注意此页面使用vue),这里涉及的是前后端分离的操作,小冷使用vue中的ajax直接请求的后台的服务器,当然后台可以用任何语言实现数据传输(可使用java,python,node,php,c++,c#等),小冷使用的是java语言编写的后台的代码,此时就涉及到了跨域。
-
首先是前台数据可以传到
-
然而后台却无法相应回前台页面(这里页面会抛一个异常,说太安全,无法获取请求后响应的数据--暂时就这样理解吧嘻嘻)
- 请求代码
-
java解决方法:
此处java使用的springboot框架,解决中使用的一个注解
@CrossOrigin(origins = "*", maxAge = 3600) //* 可以改成ip地址
加如此注解后
-
获取到响应的数据,此处注解可以配置全局,亦可以配置方法局部小冷配置为全局
此处基本跨域问题基本解决!
前端vue跨域的解决方法:
-
大家可以关注我的微信公众号”秦川以北“,里面还有好多实用的技术分享!