首先说一下什么是跨域?

JavaScript出于安全方面的考虑,不允许跨域调用其他页面的对象。那什么是跨域呢,简单地理解就是因为JavaScript同源策略的限制,域名下的js无法操作或是c.域名下的对象。
当协议、子域名、主域名、端口号中任意一个不相同时,都算作不同域。不同域之间相互请求资源,就算作“跨域”。
例如:http:///index.html 请求 http://www.efg.com/service.php。

有一点必须要注意:跨域并不是请求发不出去,请求能发出去,服务端能收到请求并正常返回结果,只是结果被浏览器拦截了。之所以会跨域,是因为受到了同源策略的限制,同源策略要求源相同才能正常进行通信,即协议、域名、端口号都完全一致。

在这之前小冷自己写了个简单的前端页面(注意此页面使用vue),这里涉及的是前后端分离的操作,小冷使用vue中的ajax直接请求的后台的服务器,当然后台可以用任何语言实现数据传输(可使用java,python,node,php,c++,c#等),小冷使用的是java语言编写的后台的代码,此时就涉及到了跨域。
首先是前台数据可以传到后台

springboot vue垂直越权_跨域


springboot vue垂直越权_跨域_02

然而后台却无法相应回前台页面(这里页面会抛一个异常,说太安全,无法获取请求后响应的数据–暂时就这样理解吧嘻嘻)

springboot vue垂直越权_跨域_03


请求代码:

springboot vue垂直越权_springboot vue垂直越权_04

java解决方法:
此处java使用的springboot框架,解决中使用的一个注解

@CrossOrigin(origins = "", maxAge = 3600) // 可以改成ip地址

加如此注解后

springboot vue垂直越权_数据_05


获取到响应的数据,此处注解可以配置全局,亦可以配置方法局部小冷配置为全局

springboot vue垂直越权_springboot vue垂直越权_06


此处基本跨域问题基本解决!