Версия 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, чтобы этот проект работал.