前后端分离,遇到跨域问题,java中的解决方案,前端不需要做跨域问题解决,只要做好后台控制就好了

这个也是我的经验只谈,不一定是完全正确的,但用我这种方式,还是可以的,目前没有发现任何问题,
为什么我不推荐用前端来解决跨域问题:
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中添加过滤器就是这么简单,就这么一个类,添加注解,就是能起作用了。

如果用的其他框架结构,道理应该是一样的,其他框架结构下的我没有实践过,道理应该也是差不多的,就是让过滤器允许跨域访问应该就可以了,配置可以参考上面的代码。

猜你喜欢

转载自blog.csdn.net/qq_27623455/article/details/89568049