http://www.tuicool.com/articles/3UBzIbb
增加如下配置:
<init-param>
<param-name>dispatchOptionsRequest</param-name>
<param-value>true</param-value>
</init-param>
加在springdispatcher 里面
<servlet>
<servlet-name>springdispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springMvc-viewresolver.xml</param-value>
</init-param>
<init-param>
<param-name>dispatchOptionsRequest</param-name>
<param-value>true</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
过滤器代码
package com.allcam.andedu.abc.filter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
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.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.allcam.andedu.abc.pojo.UserCache;
public class SystemFilter implements Filter
{
private static final List<String> STRINGS = new ArrayList<String>();
private static final String UTF8_CODE = "UTF-8";
static
{
STRINGS.add("jsp");
STRINGS.add("js");
STRINGS.add("css");
STRINGS.add("images");
STRINGS.add("backRes");
STRINGS.add("anon");
STRINGS.add("ckplayer");
STRINGS.add("htm");
STRINGS.add("ico");
STRINGS.add("uploadImage");
}
@Override
public void destroy()
{
}
@Override
public void doFilter(ServletRequest servletRequest,ServletResponse servletResponse,FilterChain chain)
throws IOException,ServletException
{
HttpServletRequest request = (HttpServletRequest)servletRequest;
HttpServletResponse response = (HttpServletResponse)servletResponse;
// 指定允许其他域名访问
response.setHeader("Access-Control-Allow-Origin","*");
// 响应类型
response.setHeader("Access-Control-Allow-Methods","POST,GET,OPTIONS,DELETE");
// 响应头设置
response.setHeader("Access-Control-Allow-Headers","Content-Type,x-requested-with,X-Custom-Header");
if ("OPTIONS".equals(request.getMethod())) { response.setStatus(204); } // response.setHeader("Access-Control-Max-Age","3600"); request.setCharacterEncoding(UTF8_CODE); response.setCharacterEncoding(UTF8_CODE); chain.doFilter(request,response); } @Override public void init(FilterConfig filterConfig) throws ServletException { } public boolean isAuth(String url) { for (String string : STRINGS) { if (url.contains(string)) { return true; } } return false; } }