Java でのフィルターの使用

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か、有効にしないと、すべてのインターフェイスがインターセプトされます。@ConfigurationurlPatterns

@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);
    }
}

おすすめ

転載: blog.csdn.net/qq_25775675/article/details/111181091