问题
因为最近在学习vue和springboot.用到了前后端分离.前端webpack打包运行的时候会启动nodejs的服务器占用8080端口,后端springboot自带tomcat启动占用1111端口(我自己设置的)...导致前端请求的ajax到后台会产生跨域问题...然后自己试了试发现有2种办法都可以解决.
利用SpringMVC @CrossOrigin注解
1 package com.labofjet.system.controller; 2 3 import org.slf4j.Logger; 4 import org.slf4j.LoggerFactory; 5 6 //@CrossOrigin(value = "*", allowCredentials = "true") 7 public class BaseController { 8 protected Logger log = LoggerFactory.getLogger(this.getClass()); 9 }
CrossOrigin这个注解可以允许ajax跨域请求....但是有个很明显的缺点就是ajax会请求2次,第一次请求类型是options.查看是不是允许发起跨域请求.然后才会发起get呀post呀这样的请求...这就很蛋疼了.相当于需要花费额外的时间再请求上.毕竟请求次数翻倍了.
另外如果要传输cookies的话似乎需要额外设置
allowCredentials = &#