JSP - Отладка

В этой главе мы обсудим отладку JSP. Всегда сложно тестировать / отлаживать JSP и сервлеты. JSP и сервлеты, как правило, требуют большого количества взаимодействий между клиентом и сервером, что делает ошибки вероятными, но их трудно воспроизвести.

Ниже приведены несколько советов и предложений, которые могут помочь вам в отладке.

Использование System.out.println ()

System.out.println()легко использовать в качестве маркера, чтобы проверить, выполняется ли определенный фрагмент кода или нет. Мы также можем распечатать значения переменных. Учтите следующие дополнительные моменты -

  • Поскольку объект System является частью основных объектов Java, его можно использовать повсюду без необходимости установки каких-либо дополнительных классов. Это включает в себяServlets, JSP, RMI, EJB's, ordinary Beans и classes, и standalone applications.

  • По сравнению с остановкой в ​​точках останова запись в System.out не сильно мешает нормальному потоку выполнения приложения, что делает его очень ценным, когда изображение имеет решающее значение.

Ниже приводится синтаксис для использования System.out.println() -

System.out.println("Debugging message");

В следующем примере показано, как использовать System.out.print() -

<%@taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>

<html>
   <head><title>System.out.println</title></head>
   <body>
      <c:forEach var = "counter" begin = "1" end = "10" step = "1" >
      
         <c:out value = "${counter-5}"/></br>
         <% System.out.println( "counter = " + pageContext.findAttribute("counter") ); %>
      </c:forEach>
      
   </body>
</html>

Получите доступ к вышеуказанному JSP, браузер покажет следующий результат -

-4
-3
-2
-1
0
1
2
3
4
5

Если вы используете Tomcat, вы также найдете эти строки добавленными в конец stdout.log в каталоге журналов.

counter = 1
counter = 2
counter = 3
counter = 4
counter = 5
counter = 6
counter = 7
counter = 8
counter = 9
counter = 10

Таким образом, вы можете занести в системный журнал переменные и другую информацию, которая может быть проанализирована для определения основной причины проблемы или по другим причинам.

Использование JDB Logger

В J2SEПлатформа ведения журналов предназначена для предоставления служб ведения журналов для любого класса, работающего в JVM. Мы можем использовать эту структуру для регистрации любой информации.

Давайте перепишем приведенный выше пример, используя JDK logger API -

<%@taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>
<%@page import = "java.util.logging.Logger" %>

<html>
   <head><title>Logger.info</title></head>
   
   <body>
      <% Logger logger = Logger.getLogger(this.getClass().getName());%>

      <c:forEach var = "counter" begin = "1" end = "10" step = "1" >
      <c:set var = "myCount" value = "${counter-5}" />
      <c:out value = "${myCount}"/></br>
         <% String message = "counter = "
            + pageContext.findAttribute("counter") + "myCount = "
            + pageContext.findAttribute("myCount");
            logger.info( message );
         %>
      </c:forEach>
      
   </body>
</html>

Приведенный выше код сгенерирует аналогичный результат в браузере и в stdout.log, но у вас будет дополнительная информация в stdout.log. Мы будем использоватьinfoметод регистратора, потому что и регистрировать сообщение только для информационных целей. Ниже приведен снимок файла stdout.log -

24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 1 myCount = -4
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 2 myCount = -3
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 3 myCount = -2
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 4 myCount = -1
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 5 myCount = 0
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 6 myCount = 1
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 7 myCount = 2
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 8 myCount = 3
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 9 myCount = 4
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 10 myCount = 5

Сообщения можно отправлять на разных уровнях с помощью удобных функций. severe(), warning(), info(), config(), fine(), finer(), и finest(). Здесь метод finest () может использоваться для регистрации самой точной информации, а метод strict () может использоваться для регистрации серьезной информации.

Вы можете использовать Log4J Framework для регистрации сообщений в разных файлах в зависимости от их уровней серьезности и важности.

Инструменты отладки

NetBeans - это бесплатная интегрированная среда разработки Java с открытым исходным кодом, которая поддерживает разработку автономных приложений Java и веб-приложений, поддерживающих спецификации JSP и сервлетов, а также включает отладчик JSP.

NetBeans поддерживает следующие основные функции отладки:

  • Breakpoints
  • Пошаговый код
  • Watchpoints

Вы можете сослаться на NetBeans documentation чтобы понять вышеуказанные функции отладки.

Использование отладчика JDB

Вы можете отлаживать JSP и сервлеты одним и тем же jdb команды, которые вы используете для отладки апплета или приложения.

Чтобы отладить JSP или сервлет, вы можете отладить sun.servlet.http.HttpServer, затем посмотрите, как HttpServer выполняет JSP / сервлеты в ответ на HTTP-запросы, которые мы делаем из браузера. Это очень похоже на отладку апплетов. Разница в том, что с апплетами отлаживаемая программаsun.applet.AppletViewer.

Большинство отладчиков скрывают эту деталь, автоматически зная, как отлаживать апплеты. Пока они не сделают то же самое для JSP, вы должны помочь своему отладчику, учитывая следующее:

  • Установите путь к классам вашего отладчика. Это поможет вам найтиsun.servlet.http.Http-Server и связанные классы.

  • Установите путь к классам вашего отладчика. Это поможет вам найти свой JSP и вспомогательные классы, обычноROOT\WEB-INF\classes.

После того, как вы установили правильный путь к классам, начните отладку sun.servlet.http.HttpServer. Вы можете установить точки останова в любом JSP, который вас интересует отладки, а затем использовать веб-браузер, чтобы сделать запрос к HttpServer для данного JSP.(http://localhost:8080/JSPToDebug). Здесь выполнение останавливается на точках останова.

Использование комментариев

Комментарии в вашем коде могут по-разному помочь процессу отладки. Комментарии могут использоваться в процессе отладки множеством других способов.

JSP использует комментарии Java и single line (// ...) и multiple line (/* ... */)комментарии могут использоваться для временного удаления частей вашего кода Java. Если ошибка исчезла, внимательно посмотрите на код, который вы только что прокомментировали, и выясните проблему.

Заголовки клиента и сервера

Иногда, когда JSP ведет себя не так, как ожидалось, полезно посмотреть на необработанный HTTP-запрос и ответ. Если вы знакомы со структурой HTTP, вы можете прочитать запрос и ответ и посмотреть, что именно происходит с этими заголовками.

Важные советы по отладке

Вот список еще нескольких советов по отладке JSP -

  • Попросите браузер показать необработанное содержимое страницы, которую он отображает. Это может помочь выявить проблемы с форматированием. Обычно это опция в меню «Просмотр».

  • Убедитесь, что браузер не кэширует вывод предыдущего запроса, принудительно перезагрузив страницу. С участиемNetscape Navigator, используйте Shift-Reload; с участиемInternet Explorer использовать Shift-Refresh.