今天查了一下CacheFilter不起作用的原因。在CacheFilter类中设置的断点,但是一直没有执行到。
觉得可能是filterchain顺序导致的。跟踪代码执行,果然是先走了struts2的filter。
改了一下filter的顺序,将cache放在chain最顶部。CacheFilter起作用了。
运行过程中仍然有问题,cache的key值没有带上查询参数。又怀疑是encoding filter顺序的额外难题。
将encoding和cache换了一下,果然好了。
?
总结:
filterchain的顺序固定,否则处理cache出错。
1、 cache时key中没有url参数
2、 cache不到struts结果
<filter>
<filter-name>Struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
</filter>
<filter>
<filter-name>cache</filter-name>
<filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class>
<init-param>
<param-name>time</param-name>
<param-value>300</param-value>
</init-param>
<init-param>
<param-name>disableCacheOnMethods</param-name>
<param-value>POST,PUT,DELETE</param-value>
</init-param>
<init-param>
<param-name>expires</param-name>
<param-value>time</param-value>
</init-param>
</filter>
<filter>
<filter-name>encoding</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GBK</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encoding</filter-name>
<url-pattern>/*.sip</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>cache</filter-name>
<url-pattern>/*.sip</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>Struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
?