最近在项目中遇到跨域的问题,现贴出代码,留作参考。
1、在web.xml配置Filter过滤器
<!--指定一个过滤器-->
<filter>
<filter-name>CorsFilter</filter-name><!--为过滤器指定一个名字-->
<filter-class>com.xwpt.core.http.SimpleCORSFilter</filter-class><!--指定过滤器的完整的限定类名,即完整类名-->
</filter>
<!--设置一个 Filter 所负责拦截的资源-->
<filter-mapping>
<filter-name>CorsFilter</filter-name><!--为过滤器指定一个名字,和上面过滤器名字一样-->
<url-pattern>*.do</url-pattern><!--设置 filter 所拦截的请求路径-->
</filter-mapping>
2、实现Filter接口
package com.xwpt.core.http;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.servlet.*;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
public class SimpleCORSFilter implements Filter {
private Logger logger = LoggerFactory.getLogger(SimpleCORSFilter.class);
@Override
public void destroy() {
// TODO Auto-generated method stub
}
@Override
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
// TODO Auto-generated method stub
HttpServletResponse httpServletResponse = (HttpServletResponse) response;
//"Access-Control-Allow-Origin"是响应头的信任站点,* 表示允许任意访问请求
httpServletResponse.setHeader("Access-Control-Allow-Origin", "*");
httpServletResponse.setHeader("Access-Control-Allow-Headers", "accept,content-type,token");
httpServletResponse.setHeader("Access-Control-Allow-Methods", "OPTIONS,GET,POST,DELETE,PUT");
chain.doFilter(request, httpServletResponse);
}
@Override
public void init(FilterConfig arg0) throws ServletException {
// TODO Auto-generated method stub
logger.info("======初始化,允许跨域请求=========");
}
}