JSP - Gestion des exceptions

Dans ce chapitre. nous verrons comment gérer les exceptions dans JSP. Lorsque vous écrivez un code JSP, vous pouvez faire des erreurs de codage qui peuvent survenir à n'importe quelle partie du code. Il peut se produire le type d'erreurs suivant dans votre code JSP -

Exceptions vérifiées

Une exception vérifiée est une exception qui est généralement une erreur de l'utilisateur ou un problème qui ne peut pas être prévu par le programmeur. Par exemple, si un fichier doit être ouvert, mais que le fichier est introuvable, une exception se produit. Ces exceptions ne peuvent tout simplement pas être ignorées au moment de la compilation.

Exceptions d'exécution

Une exception d'exécution est une exception qui aurait probablement pu être évitée par le programmeur. Contrairement aux exceptions vérifiées, les exceptions d'exécution sont ignorées au moment de la compliation.

les erreurs

Ce ne sont pas du tout des exceptions, mais des problèmes qui surgissent au-delà du contrôle de l'utilisateur ou du programmeur. Les erreurs sont généralement ignorées dans votre code car vous pouvez rarement faire quoi que ce soit en cas d'erreur. Par exemple, si un débordement de pile se produit, une erreur se produit. Ils sont également ignorés au moment de la compilation.

Nous discuterons plus en détail des moyens de gérer les exceptions / erreurs d'exécution survenant dans votre code JSP.

Utilisation d'un objet d'exception

L'objet d'exception est une instance d'une sous-classe de Throwable (par exemple, java.lang. NullPointerException) et n'est disponible que dans les pages d'erreur. Le tableau suivant répertorie les méthodes importantes disponibles dans la classe Throwable.

S.No. Méthodes et description
1

public String getMessage()

Renvoie un message détaillé sur l'exception qui s'est produite. Ce message est initialisé dans le constructeur Throwable.

2

public Throwable getCause()

Renvoie la cause de l'exception représentée par un objet Throwable.

3

public String toString()

Renvoie le nom de la classe concaténée avec le résultat de getMessage().

4

public void printStackTrace()

Imprime le résultat de toString() avec la trace de pile vers System.err, le flux de sortie d'erreur.

5

public StackTraceElement [] getStackTrace()

Renvoie un tableau contenant chaque élément de la trace de pile. L'élément à l'index 0 représente le haut de la pile d'appels et le dernier élément du tableau représente la méthode au bas de la pile d'appels.

6

public Throwable fillInStackTrace()

Remplit la trace de pile de cet objet Throwable avec la trace de pile actuelle, en ajoutant à toutes les informations précédentes dans la trace de pile.

JSP vous donne la possibilité de spécifier Error Pagepour chaque JSP. Chaque fois que la page lève une exception, le conteneur JSP appelle automatiquement la page d'erreur.

Voici un exemple pour spécifier une page d'erreur pour un main.jsp. Pour configurer une page d'erreur, utilisez le<%@ page errorPage = "xxx" %> directif.

<%@ page errorPage = "ShowError.jsp" %>

<html>
   <head>
      <title>Error Handling Example</title>
   </head>
   
   <body>
      <%
         // Throw an exception to invoke the error page
         int x = 1;
         
         if (x == 1) {
            throw new RuntimeException("Error condition!!!");
         }
      %>
   </body>
</html>

Nous allons maintenant écrire une JSP de gestion des erreurs ShowError.jsp, qui est donnée ci-dessous. Notez que la page de gestion des erreurs inclut la directive<%@ page isErrorPage = "true" %>. Cette directive oblige le compilateur JSP à générer la variable d'instance d'exception.

<%@ page isErrorPage = "true" %>

<html>
   <head>
      <title>Show Error Page</title>
   </head>
   
   <body>
      <h1>Opps...</h1>
      <p>Sorry, an error occurred.</p>
      <p>Here is the exception stack trace: </p>
      <pre><% exception.printStackTrace(response.getWriter()); %></pre>
   </body>
</html>

Accéder au main.jsp, vous recevrez une sortie un peu comme celle-ci -

java.lang.RuntimeException: Error condition!!!
......

Opps...
Sorry, an error occurred.

Here is the exception stack trace:

Utilisation des balises JSTL pour la page d'erreur

Vous pouvez utiliser les balises JSTL pour écrire une page d'erreur ShowError.jsp. Cette page a presque la même logique que dans l'exemple ci-dessus, avec une meilleure structure et plus d'informations -

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

<html>
   <head>
      <title>Show Error Page</title>
   </head>
   
   <body>
      <h1>Opps...</h1>
      <table width = "100%" border = "1">
         <tr valign = "top">
            <td width = "40%"><b>Error:</b></td>
            <td>${pageContext.exception}</td>
         </tr>
            
         <tr valign = "top">
            <td><b>URI:</b></td>
            <td>${pageContext.errorData.requestURI}</td>
         </tr>
            
         <tr valign = "top">
            <td><b>Status code:</b></td>
            <td>${pageContext.errorData.statusCode}</td>
         </tr>
            
         <tr valign = "top">
            <td><b>Stack trace:</b></td>
            <td>
               <c:forEach var = "trace" 
                  items = "${pageContext.exception.stackTrace}">
                  <p>${trace}</p>
               </c:forEach>
            </td>
         </tr>
      </table>

   </body>
</html>

Accédez au fichier main.jsp, ce qui suit sera généré -

Opps...

Error:

java.lang.RuntimeException: Error condition!!!

URI:

/main.jsp

Status code:

500

Stack trace:

org.apache.jsp.main_jsp._jspService(main_jsp.java:65)

org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:68)

javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

org.apache.jasper.servlet.JspServlet.service(JspServlet.java:265)

javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

Utilisation de Try ... Catch Block

Si vous souhaitez gérer des erreurs dans la même page et que vous souhaitez prendre des mesures au lieu de déclencher une page d'erreur, vous pouvez utiliser le try....catch bloquer.

Voici un exemple simple qui montre comment utiliser le bloc try ... catch. Mettons le code suivant dans main.jsp -

<html>
   <head>
      <title>Try...Catch Example</title>
   </head>
   
   <body>
      <%
         try {
            int i = 1;
            i = i / 0;
            out.println("The answer is " + i);
         }
         catch (Exception e) {
            out.println("An exception occurred: " + e.getMessage());
         }
      %>
   </body>
</html>

Accédez au fichier main.jsp, il devrait générer une sortie un peu comme celle-ci -

An exception occurred: / by zero