我制作了一个过滤器,负责向请求添加.do
,并且是第一个声明的过滤器:
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
if(! (request instanceof HttpServletRequest)){
chain.doFilter(request, response );
}
HttpServletRequest httpServletRequest = (HttpServletRequest) request;
String requestUrl = httpServletRequest.getServletPath();
if(!isBetaPathRequest(httpServletRequest) || StringUtils.contains(requestUrl,".")){
chain.doFilter(request, response );
return;
}
String newUrl = requestUrl;
int lastIndexOf = requestUrl.lastIndexOf("?");
if(lastIndexOf == -1){
if(requestUrl.charAt(requestUrl.length()-1) != '/'){
newUrl = newUrl.concat(".do");
}
}
else{
newUrl = requestUrl.substring(0, lastIndexOf-1) .concat(".do") .concat(requestUrl.substring(lastIndexOf));
}
final RequestDispatcher rq = getRequestDispatcher(request, newUrl);
rq.forward(request, response);
}
项目web.xml
文件中还声明了其他各种过滤器,我注意到调试器没有运行它们。
例如,一个重要过滤器的当前映射是:
内容响应缓存筛选器 *。做
但是初始传入请求在通过BetaRewriteUrlFilter
之前不包括 URl 中的.do
。
当调用 RequestDispatcher.forward 时,是否应用了过滤器,或者我们是否需要手动校准它们还是使用 302 重定向???
我最终做的是将这个新过滤器放在网络上.xml定义。
此重写过滤器需要位于链上的最后一个,因为使用request dispatcher
forward
方法不会破坏功能或禁止其他过滤器的运行。