1. import org.springframework.stereotype.Component;
    2. import javax.servlet.*;
    3. import javax.servlet.http.HttpServletRequest;
    4. import javax.servlet.http.HttpServletResponse;
    5. import java.io.IOException;
    6. /**
    7. * 跨域拦截器
    8. */
    9. @Component
    10. public class CorsFilter implements Filter {
    11. @Override
    12. public void init(FilterConfig filterConfig) throws ServletException {
    13. }
    14. @Override
    15. public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
    16. HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest;
    17. HttpServletResponse httpServletResponse = (HttpServletResponse) servletResponse;
    18. //这里填写你允许进行跨域的主机ip
    19. httpServletResponse.setHeader("Access-Control-Allow-Origin", "*");
    20. //允许的访问方法
    21. httpServletResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, OPTIONS, DELETE, PATCH");
    22. //Access-Control-Max-Age 用于 CORS 相关配置的缓存
    23. httpServletResponse.setHeader("Access-Control-Max-Age", "3600");
    24. httpServletResponse.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
    25. String userId = servletRequest.getParameter("userId");
    26. String token = servletRequest.getParameter("token");
    27. filterChain.doFilter(servletRequest, servletResponse);
    28. }
    29. @Override
    30. public void destroy() {
    31. }
    32. }