I. 概要
2 番目に、Spring の使用
web.xml
フィルターのプロキシ クラスがファイルに追加され、targetBeanName
その値がフィルターの値になりますid
。それ@Component("authFilter")
は にありますauthFilter
。
<!-- 统一认证过滤器的代理 -->
<filter>
<filter-name>DelegatingFilterProxy</filter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
<init-param>
<param-name>targetBeanName</param-name>
<param-value>authFilter</param-value>
</init-param>
<init-param>
<param-name>targetFilterLifecycle</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>DelegatingFilterProxy</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
@Component()
パラメーターがない場合、デフォルト値はクラス名の最初の小文字です。
/**
* 统一认证过滤器
*/
@Component("authFilter")
public class AuthFilter implements Filter {
protected static final Logger logger = LoggerFactory.getLogger(AuthFilter.class);
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
HttpServletRequest httpRequest = (HttpServletRequest)request;
HttpServletResponse httpResponse = (HttpServletResponse)response;
HttpSession session = httpRequest.getSession();
}
}
3. SpringBootの使用
1. 方法 1
@WebFilter(filterName = "dataFilter", urlPatterns = "/api/*")
@Order(1)
public class DataFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
chain.doFilter(request, response);
}
@Override
public void destroy() {
}
}
スタートアップクラスに@ServletComponentScan
アノテーションを追加する
//@ServletComponentScan({"com.scy.frame", "com.scy.app"})
@ServletComponentScan
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(VideoScreenApplication.class, args);
}
}
@ServletComponentScan は
SpringBootApplication で動作します。SpringBootApplication で @ServletComponentScan アノテーションを使用した後、
サーブレットは @WebServlet アノテーションを介して
直接自動的に登録できます。フィルタは @WebFilter アノテーションを介して直接
自動登録できます。リスナーは、 @WebListener アノテーション。
2.方法2
@WebFilter
フィルターを宣言する方法は使用せず、FilterRegistrationBean
フィルターを構成クラスに挿入する方法を使用してください。
@Configuration
public class FilterConfiguration {
@Bean
public FilterRegistrationBean dataFilter(){
FilterRegistrationBean bean = new FilterRegistrationBean();
bean.setFilter(new DataFilter());
bean.setUrlPatterns(Arrays.asList("/api/*"));
bean.setOrder(6);//优先级,越低越优先
return bean;
}
}
3. 方法 3 (問題)
@ServletComponentScan
スタートアップ クラスにアノテーションを追加しないでください。指定したインターセプト パスを使用する@Component
か、有効にしないと、すべてのインターフェイスがインターセプトされます。@Configuration
urlPatterns
@Component
@WebFilter(filterName = "dataFilter", urlPatterns = "/api/*")
@Order(1)
public class DataFilter implements Filter {
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
chain.doFilter(request, response);
}
}