使用servlet过滤器实现跨域功能
Posted cjq.java
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用servlet过滤器实现跨域功能相关的知识,希望对你有一定的参考价值。
1.定义过滤器接口Filter的实现类,实现类中修改respone的头信息,把 “Access-Control-Allow-Origin” 的域名修改问请求方的域名,如下:
package filter;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletResponse;
public class CORSFilter implements Filter {
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
HttpServletResponse response = (HttpServletResponse) res;
response.setHeader("Access-Control-Allow-Origin", "*");
response.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, OPTIONS, DELETE");
response.setHeader("Access-Control-Max-Age", "3600");
response.setHeader("Access-Control-Allow-Headers", "x-requested-with, Content-Type");
response.setHeader("Access-Control-Allow-Credentials", "true");
chain.doFilter(req, res);
}
public void init(FilterConfig filterConfig) {}
public void destroy() {} }
<filter>
<filter-name>CORSFilter</filter-name>
<filter-class>com.exiao.platform.api.supplier.filter.CORSFilter</filter-class>
</filter>
---------------------------------------------------------------------------------------------------------------------------------------------------------
springboot 服务器端设置允许跨域
package cn.xydata.util;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
/**
* 跨域过滤器
* @author cjq
* @since 2017年9月26日
*/
@Component
public class CorsFilterUtil implements Filter {
private static final Logger logger = LoggerFactory.getLogger(CorsFilterUtil.class);
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
HttpServletResponse response = (HttpServletResponse) res;
response.setHeader("Access-Control-Allow-Origin", "*");
response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE,PUT,OPTIONS,PATCH");
response.setHeader("Access-Control-Max-Age", "3600");
response.setHeader("Access-Control-Allow-Headers", "x-requested-with");
System.out.println("*********************************过滤器被使用**************************");
chain.doFilter(req, res);
}
public void init(FilterConfig filterConfig) {}
public void destroy() {}
}
以上是关于使用servlet过滤器实现跨域功能的主要内容,如果未能解决你的问题,请参考以下文章
tomcat跨域请求过滤器CorsFilter使用的预检preFlight及其他过滤器
Gateway网关(快速入门断言工厂过滤器工厂全局过滤器),解决跨域问题