这个也是我的经验只谈,不一定是完全正确的,但用我这种方式,还是可以的,目前没有发现任何问题,
为什么我不推荐用前端来解决跨域问题:
1、代码复用性不高,那么维护就困难了
2、很多跨域方式弊端很多,有的不能post请求啊,文件上传限制啊等等(个人遇到的问题,不代表所有人的观点)
所有建议在后台做跨域解决
我的项目框架:springboot
只要在项目中添加一个过滤器就可以了,如下:
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@Component
@WebFilter(urlPatterns = "/*",filterName = "myFilter")
public class MyFilter implements Filter {
Logger loger = LoggerFactory.getLogger(MyFilter.class);
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest sRequest, ServletResponse sResponse, FilterChain chain) throws IOException, ServletException {
HttpServletResponse response = (HttpServletResponse) sResponse;
response.setHeader("Access-Control-Allow-Origin", "*"); //解决跨域访问报错
response.setHeader("Access-Control-Allow-Credentials","true");
response.setHeader("Access-Control-Allow-Methods", "POST, PUT, GET, OPTIONS, DELETE");
response.setHeader("Access-Control-Max-Age", "3600"); //设置过期时间
response.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, client_id, uuid, Authorization");
response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // 支持HTTP 1.1.
response.setHeader("Pragma", "no-cache"); // 支持HTTP 1.0. response.setHeader("Expires", "0");
chain.doFilter(sRequest, sResponse);
}
@Override
public void destroy() {
}
}
在springboot中添加过滤器就是这么简单,就这么一个类,添加注解,就是能起作用了。
如果用的其他框架结构,道理应该是一样的,其他框架结构下的我没有实践过,道理应该也是差不多的,就是让过滤器允许跨域访问应该就可以了,配置可以参考上面的代码。