|
|
@@ -0,0 +1,47 @@
|
|
|
+package com.uas.kanban;
|
|
|
+
|
|
|
+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;
|
|
|
+
|
|
|
+import org.springframework.stereotype.Component;
|
|
|
+
|
|
|
+/**
|
|
|
+ * 跨域访问
|
|
|
+ *
|
|
|
+ * @author sunyj
|
|
|
+ * @since 2017年9月5日 下午10:45:32
|
|
|
+ */
|
|
|
+@Component
|
|
|
+public class CORSFilter implements Filter {
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
|
|
|
+ throws IOException, ServletException {
|
|
|
+ HttpServletResponse httpServletResponse = (HttpServletResponse) response;
|
|
|
+ // 不需要限制的域,可以配置多个
|
|
|
+ httpServletResponse.setHeader("Access-Control-Allow-Origin", "*");
|
|
|
+ // 允许请求的方法
|
|
|
+ httpServletResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
|
|
|
+ // 表明在3600秒内,不需要再发送预检验请求,可以缓存该结果
|
|
|
+ httpServletResponse.setHeader("Access-Control-Max-Age", "3600");
|
|
|
+ // 表明它允许跨域请求包含x-requested-with头
|
|
|
+ httpServletResponse.setHeader("Access-Control-Allow-Headers", "x-requested-with");
|
|
|
+ chain.doFilter(request, response);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void init(FilterConfig filterConfig) throws ServletException {
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void destroy() {
|
|
|
+ }
|
|
|
+
|
|
|
+}
|