什么是跨域?
跨域,是由浏览器的同源策略造成的,是浏览器施加的安全限制。
同源是指域名、协议、端口均相同
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,跨域)
注意:localhost和127.0.0.1虽然都指向本机,但也属于跨域。
http和https属于不同协议,属于跨域
SpringCloud项目中如何解决跨域问题?
在微服务框架中,常常涉及到在一个服务器对应的业务逻辑中要调用另一个服务器的业务逻辑(端口就会不一致,甚至于主机不一致即IP地址不一致或者两个业务的域名不一致),或者前端和后端不在一台主机的服务器上出现的跨域问题。
可以通过在Controller中使用@CrossOrigin注解解决跨域问题。