⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 loggingfilter.java

📁 pebble-blog 博客源码博客源码博客源码
💻 JAVA
字号:
/* * Copyright (c) 2003-2006, Simon Brown * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * *   - Redistributions of source code must retain the above copyright *     notice, this list of conditions and the following disclaimer. * *   - Redistributions in binary form must reproduce the above copyright *     notice, this list of conditions and the following disclaimer in *     the documentation and/or other materials provided with the *     distribution. * *   - Neither the name of Pebble nor the names of its contributors may *     be used to endorse or promote products derived from this software *     without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */package net.sourceforge.pebble.web.filter;import net.sourceforge.pebble.Constants;import net.sourceforge.pebble.domain.FileMetaData;import net.sourceforge.pebble.domain.Blog;import net.sourceforge.pebble.domain.AbstractBlog;import net.sourceforge.pebble.util.SecurityUtils;import javax.servlet.*;import javax.servlet.http.HttpServletRequest;import java.io.IOException;import java.util.regex.Pattern;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;/** * A filter that logs certain incoming requests. * * @author    Simon Brown */public class LoggingFilter implements Filter {  private static final Log log = LogFactory.getLog(LoggingFilter.class);  private static final Pattern ACTION_REGEX = Pattern.compile("/[\\w]*\\.action.*");  private static final Pattern SECURE_ACTION_REGEX= Pattern.compile("/[\\w]*\\.secureaction.*");  /** the config of this filter */  private FilterConfig filterConfig;  /**   * Initialises this instance.   *   * @param config    a FilterConfig instance   */  public void init(FilterConfig config) {    this.filterConfig = config;  }  /**   * Called when this filter is taken out of service.   */  public void destroy() {  }  /**   * Contains the processing associated with this filter.   */  public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)      throws ServletException, IOException {    HttpServletRequest httpRequest = (HttpServletRequest)request;    AbstractBlog abstractBlog = (AbstractBlog)request.getAttribute(Constants.BLOG_KEY);    String internalUri = (String)request.getAttribute(Constants.INTERNAL_URI);    String externalUri = (String)request.getAttribute(Constants.EXTERNAL_URI);    if (abstractBlog instanceof Blog) {      Blog blog = (Blog)abstractBlog;      if (ACTION_REGEX.matcher(internalUri).matches() || SECURE_ACTION_REGEX.matcher(internalUri).matches()) {//        log.info("Logging " + externalUri);//      // this is the list of URIs that get logged//      if (internalUri.startsWith("/feed.action") ||//          internalUri.startsWith("/responseFeed.action") ||//          internalUri.startsWith("/viewCategories.action") ||//          internalUri.startsWith("/viewCategory.action") ||//          internalUri.startsWith("/viewTags.action") ||//          internalUri.startsWith("/viewTag.action") ||//          internalUri.startsWith("/search.action") ||//          internalUri.startsWith("/aboutAuthor.action") ||//          internalUri.startsWith("/viewBlogEntry.action") ||//          internalUri.startsWith("/viewStaticPage.action") ||//          internalUri.startsWith("/viewDay.action") ||//          internalUri.startsWith("/viewMonth.action") ||//          internalUri.startsWith("/file.action?type=" + FileMetaData.BLOG_FILE) ||//          internalUri.startsWith("/viewBlogEntriesByPage.action") ||//          (internalUri.startsWith("/viewHomePage.action") && blog instanceof Blog)) {////        blog.log(httpRequest);      }    }    chain.doFilter(request, response);  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -