Writing your own Tomcat Valve

You can extend from org.apache.catalina.valves.ValveBase and implement the method invoke. The following example just prints out is has been called and invokes the next Valve.


import javax.servlet.http.*;
import javax.servlet.*;
import java.util.*;
import java.io.*;
import org.apache.catalina.valves.*;
import org.apache.catalina.*;
public class MyValve extends ValveBase
    * The descriptive information related to this implementation.
   private static final String info = "MyValve/1.0";
    * Return descriptive information about this Valve implementation.
   public String getInfo() {
      return (info);
   public void invoke(Request request, Response response, ValveContext context)
                             throws IOException, ServletException {
      // Skip logging for non-HTTP requests and responses
      if (!(request instanceof HttpRequest) ||
          !(response instanceof HttpResponse)) {
         context.invokeNext(request, response);
      HttpRequest httpRequest   = (HttpRequest) request;
      HttpResponse httpResponse = (HttpResponse) response;
      HttpServletRequest httpServletRequest   = (HttpServletRequest) httpRequest.getRequest();
      HttpServletResponse httpServletResponse = (HttpServletResponse) httpResponse.getResponse();
      System.out.println("nnnMyValve invokednnn");
      // continue processing the request
      context.invokeNext(request, response);
   public String toString() {
      StringBuffer sb = new StringBuffer();
      if (container != null) {
      return sb.toString();

Compile it with catalina.jar and servlet.jar in your classpath and place it in /server/classes.