多个Filter的执行顺序是如何确定

本文深入探讨了如何将Struts2框架与Security Filter结合使用,详细介绍了过滤器的顺序执行流程、配置方式及关键作用。

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee   http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
 <!-- 第一:多个filter会依次运行,按照:过滤器1->过滤器2->过滤器3->程序->过滤器3->过滤器2->过滤器1 的顺序运行 -->
  <!-- 第二:多个filter的顺序是由<filter-mapping>的先后决定的 -->
 <!-- 第三:一般dispatchar必须有forward和request -->
 <filter>
  <filter-name>struts2filter</filter-name>
  <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
 </filter>
 <filter>
  <filter-name>security</filter-name>
  <filter-class>filter.action.SecurityFilter</filter-class>
 </filter>
 
 
 <filter-mapping>
  <filter-name>struts2filter</filter-name>
  <url-pattern>/*</url-pattern>
  <dispatcher>FORWARD</dispatcher>
  <dispatcher>INCLUDE</dispatcher>
  <dispatcher>REQUEST</dispatcher>
  <dispatcher>ERROR</dispatcher>
 </filter-mapping>
 <filter-mapping>
  <filter-name>security</filter-name>
  <url-pattern>*.action</url-pattern>
 <dispatcher>FORWARD</dispatcher> 
 <dispatcher>INCLUDE</dispatcher> 
  <dispatcher>REQUEST</dispatcher>
  <dispatcher>ERROR</dispatcher>
 </filter-mapping>



 
 
在 Lucene 中,查询多个条件时的执行顺序和优化策略主要依赖于查询语句的构造方式以及 Lucene 的内部优化机制。Lucene 提供了多种查询类型(如 `BooleanQuery`、`TermQuery`、`PhraseQuery` 等),其中最常用于组合多个条件的是 `BooleanQuery`。它支持 `MUST`、`SHOULD`、`MUST_NOT` 等布尔逻辑操作符,这些操作符决定了查询条件之间的逻辑关系以及执行顺序。 ### 查询执行顺序 在 `BooleanQuery` 中,Lucene 会根据查询条件的匹配成本(cost)和文档频率(document frequency)对子查询进行排序优化。这意味着查询条件的执行顺序可能与代码中定义的顺序不同。Lucene 会优先执行成本较低或过滤效果更强的查询条件,以减少后续查询的计算量。例如,一个匹配较少文档的 `TermQuery` 可能会被优先执行[^1]。 ### 查询优化策略 Lucene 的查询优化策略包括: 1. **短路优化**:在 `BooleanQuery` 中,如果某个 `MUST` 条件无法满足,则后续条件可能不会执行2. **过滤器优化**:某些查询(如 `TermQuery`)可以被缓存为 `Filter`,以提高重复查询的性能。 3. **查询重写**:Lucene 会自动将某些查询重写为更高效的等价形式,例如将 `TermQuery` 转换为 `ConstantScoreQuery`。 ### 查询条件的显式控制 如果需要显式控制查询条件的执行顺序,可以通过以下方式实现: 1. **使用 `BooleanQuery.Builder` 显式定义条件顺序**。 2. **使用 `ConstantScoreQuery` 或 `Filter` 强制按特定顺序执行**。 ### 示例代码 以下是一个简单的 `BooleanQuery` 示例,展示了如何组合多个查询条件: ```java BooleanQuery.Builder booleanQueryBuilder = new BooleanQuery.Builder(); booleanQueryBuilder.add(new TermQuery(new Term("gender", "male")), BooleanClause.Occur.MUST); booleanQueryBuilder.add(new TermQuery(new Term("age", "30")), BooleanClause.Occur.MUST); Query query = booleanQueryBuilder.build(); ``` 在上述代码中,Lucene 会根据内部优化策略决定两个 `TermQuery` 的执行顺序,而不是严格按照代码中的添加顺序。 ### 查询性能分析 为了进一步分析查询性能,可以使用 Lucene 的 `Explanation` 类来查看查询的执行细节。这有助于理解 Lucene 如何评估每个文档的匹配度,并提供有关查询执行顺序的详细信息。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值