Статьи

Использование фильтра сервлетов Java для перехвата кода состояния ответа HTTP с IDE NetBeans 7 и Maven

Версия 2.3 спецификации сервлета Java представила концепцию фильтров . Согласно документации с сайта Oracle : «Фильтр динамически перехватывает запросы и ответы для преобразования или использования информации, содержащейся в запросах или ответах». Сегодня я покажу вам, как создать простой фильтр для перехвата HTTP-кода ответа с помощью аннотаций, представленных в спецификации Servlet 3.0 .

В среде IDE NetBeans 7 создайте новое веб-приложение Maven Java с именем: Intercept

Удалите файл index.jsp в папке « Веб-страницы ». Щелкните правой кнопкой мыши по проекту и добавьте новый сервлет с именем: MainServlet

Поскольку мы используем новые аннотации Servlet 3, нам не нужно устанавливать много свойств.

Maven создает для нас приличный файл MainServlet.java , я просто удалил комментарии для вывода. Мой файл выглядит так:

package com.giantflyingsaucer.intercept;
 
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
@WebServlet(name = "MainServlet", urlPatterns = {"/"})
public class MainServlet extends HttpServlet {
 
    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/html;charset=UTF-8");
        PrintWriter out = response.getWriter();
        try {
 
            out.println("<html>");
            out.println("<head>");
            out.println("<title>Servlet MainServlet</title>");
            out.println("</head>");
            out.println("<body>");
            out.println("<h1>Servlet MainServlet</h1>");
            out.println("</body>");
            out.println("</html>");
        } finally {
            out.close();
        }
    }
 
    // <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">
    /**
     * Handles the HTTP <code>GET</code> method.
     * @param request servlet request
     * @param response servlet response
     * @throws ServletException if a servlet-specific error occurs
     * @throws IOException if an I/O error occurs
     */
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        processRequest(request, response);
    }
 
    /**
     * Handles the HTTP <code>POST</code> method.
     * @param request servlet request
     * @param response servlet response
     * @throws ServletException if a servlet-specific error occurs
     * @throws IOException if an I/O error occurs
     */
    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        processRequest(request, response);
    }
 
    /**
     * Returns a short description of the servlet.
     * @return a String containing servlet description
     */
    @Override
    public String getServletInfo() {
        return "Short description";
    }// </editor-fold>
}
 

Щелкните правой кнопкой мыши по проекту и добавьте фильтр с именем: InterceptFilter.

Мы добавим следующие две строки в метод doFilter .

HttpServletResponse hsr = (HttpServletResponse) response;
System.out.println("HTTP Status: " + hsr.getStatus());

Мой метод doFilter выглядит так:

@Override
public void doFilter(ServletRequest request, ServletResponse response,
        FilterChain chain)
        throws IOException, ServletException {
 
    if (debug) {
        log("InterceptFilter:doFilter()");
    }
 
    doBeforeProcessing(request, response);
 
    HttpServletResponse hsr = (HttpServletResponse) response;
    System.out.println("HTTP Status: " + hsr.getStatus());       
 
    Throwable problem = null;
    try {
        chain.doFilter(request, response);
    } catch (Throwable t) {
        problem = t;
        t.printStackTrace();
    }
 
    doAfterProcessing(request, response);
 
    if (problem != null) {
        if (problem instanceof ServletException) {
            throw (ServletException) problem;
        }
        if (problem instanceof IOException) {
            throw (IOException) problem;
        }
        sendProcessingError(problem, response);
    }
}

Очистите и соберите проект и разверните его в Apache Tomcat. Получите доступ к URL через браузер и посмотрите на свой файл catalina.out, и вы увидите код ответа HTTP.

Примечание. Вам не нужно вносить какие-либо изменения в файл web.xml, чтобы этот проект работал.

С http://www.giantflyingsaucer.com/blog/?p=3279