JSP - Guide rapide

Qu'est-ce que les pages JavaServer?

JavaServer Pages (JSP) est une technologie de développement de pages Web prenant en charge le contenu dynamique. Cela aide les développeurs à insérer du code Java dans les pages HTML en utilisant des balises JSP spéciales, dont la plupart commencent par <% et se terminent par%>.

Un composant JavaServer Pages est un type de servlet Java conçu pour remplir le rôle d'interface utilisateur pour une application Web Java. Les développeurs Web écrivent des JSP sous forme de fichiers texte qui combinent du code HTML ou XHTML, des éléments XML et des actions et commandes JSP intégrées.

À l'aide de JSP, vous pouvez collecter les entrées des utilisateurs via des formulaires de page Web, présenter des enregistrements d'une base de données ou d'une autre source et créer des pages Web de manière dynamique.

Les balises JSP peuvent être utilisées à diverses fins, telles que la récupération d'informations à partir d'une base de données ou l'enregistrement des préférences de l'utilisateur, l'accès aux composants JavaBeans, le passage du contrôle entre les pages et le partage d'informations entre les demandes, les pages, etc.

Pourquoi utiliser JSP?

Les pages JavaServer ont souvent le même objectif que les programmes implémentés à l'aide de Common Gateway Interface (CGI). Mais JSP offre plusieurs avantages par rapport au CGI.

  • Les performances sont nettement meilleures car JSP permet d'incorporer des éléments dynamiques dans les pages HTML elle-même au lieu d'avoir des fichiers CGI séparés.

  • Les JSP sont toujours compilés avant d'être traités par le serveur contrairement à CGI / Perl qui oblige le serveur à charger un interpréteur et le script cible à chaque fois que la page est demandée.

  • Les pages JavaServer sont construites au-dessus de l'API Java Servlets, donc comme les servlets, JSP a également accès à toutes les puissantes API Enterprise Java, y compris JDBC, JNDI, EJB, JAXP, etc.

  • Les pages JSP peuvent être utilisées en combinaison avec des servlets qui gèrent la logique métier, le modèle pris en charge par les moteurs de modèle de servlet Java.

Enfin, JSP fait partie intégrante de Java EE, une plate-forme complète pour les applications d'entreprise. Cela signifie que JSP peut jouer un rôle dans les applications les plus simples aux plus complexes et exigeantes.

Avantages de JSP

Le tableau suivant répertorie les autres avantages de l'utilisation de JSP par rapport aux autres technologies -

vs Active Server Pages (ASP)

Les avantages de JSP sont doubles. Tout d'abord, la partie dynamique est écrite en Java, et non en Visual Basic ou dans un autre langage spécifique à MS, elle est donc plus puissante et plus facile à utiliser. Deuxièmement, il est portable vers d'autres systèmes d'exploitation et serveurs Web non Microsoft.

vs Servlets purs

Il est plus pratique d'écrire (et de modifier!) Du HTML normal que d'avoir beaucoup d'instructions println qui génèrent le HTML.

vs Server-Side includes (SSI)

SSI n'est vraiment destiné qu'aux inclusions simples, pas aux programmes «réels» qui utilisent des données de formulaire, établissent des connexions à des bases de données, etc.

vs JavaScript

JavaScript peut générer du HTML dynamiquement sur le client mais peut difficilement interagir avec le serveur Web pour effectuer des tâches complexes telles que l'accès à la base de données et le traitement d'images, etc.

vs HTML statique

Le HTML ordinaire, bien sûr, ne peut pas contenir d'informations dynamiques.

Quelle est la prochaine?

Je vous guiderais étape par étape pour configurer votre environnement pour commencer avec JSP. Je suppose que vous avez de bonnes connaissances de la programmation Java pour poursuivre l'apprentissage de JSP.

Si vous ne connaissez pas le langage de programmation Java, nous vous recommandons de suivre notre didacticiel Java pour comprendre la programmation Java.

Un environnement de développement est l'endroit où vous développez vos programmes JSP, les testez et enfin les exécutez.

Ce didacticiel vous guidera pour configurer votre environnement de développement JSP, ce qui implique les étapes suivantes -

Configuration du kit de développement Java

Cette étape implique le téléchargement d'une implémentation du kit de développement logiciel Java (SDK) et la configuration appropriée de la variable d'environnement PATH.

Vous pouvez télécharger le SDK à partir du site Java d'Oracle - Téléchargements Java SE .

Une fois que vous avez téléchargé votre implémentation Java, suivez les instructions données pour installer et configurer la configuration. Enfin, définissez lePATH and JAVA_HOME variables d'environnement pour faire référence au répertoire qui contient java et javac, typiquement java_install_dir/bin et java_install_dir respectivement.

Si vous exécutez Windows et installez le SDK dans C:\jdk1.5.0_20, vous devez ajouter la ligne suivante dans votre C:\autoexec.bat fichier.

set PATH = C:\jdk1.5.0_20\bin;%PATH%
set JAVA_HOME = C:\jdk1.5.0_20

Alternativement, sur Windows NT/2000/XP, vous pouvez également cliquer avec le bouton droit sur My Computer, sélectionnez Properties, puis Advanced, suivi par Environment Variables. Ensuite, vous mettriez à jour la valeur PATH et appuyez sur le bouton OK.

Sous Unix (Solaris, Linux, etc.), si le SDK est installé /usr/local/jdk1.5.0_20 et vous utilisez le shell C, vous mettrez ce qui suit dans votre .cshrc fichier.

setenv PATH /usr/local/jdk1.5.0_20/bin:$PATH
setenv JAVA_HOME /usr/local/jdk1.5.0_20

Sinon, si vous utilisez un Integrated Development Environment (IDE) comme Borland JBuilder, Eclipse, IntelliJ IDEA, ou Sun ONE Studio, compilez et exécutez un programme simple pour confirmer que l'EDI sait où vous avez installé Java.

Configuration du serveur Web: Tomcat

Un certain nombre de serveurs Web prenant en charge le développement de pages JavaServer et de servlets sont disponibles sur le marché. Certains serveurs Web peuvent être téléchargés gratuitement et Tomcat est l'un d'entre eux.

Apache Tomcat est une implémentation logicielle open source des technologies JavaServer Pages et Servlet et peut servir de serveur autonome pour tester les JSP et les servlets, et peut être intégré au serveur Web Apache. Voici les étapes pour configurer Tomcat sur votre machine -

  • Téléchargez la dernière version de Tomcat sur https://tomcat.apache.org/.

  • Une fois que vous avez téléchargé l'installation, décompressez la distribution binaire dans un emplacement pratique. Par exemple, dansC:\apache-tomcat-5.5.29 on windows, or /usr/local/apache-tomcat-5.5.29 sous Linux / Unix et créez CATALINA_HOME variable d'environnement pointant vers ces emplacements.

Tomcat peut être démarré en exécutant les commandes suivantes sur la machine Windows -

%CATALINA_HOME%\bin\startup.bat
 
or
 
C:\apache-tomcat-5.5.29\bin\startup.bat

Tomcat peut être démarré en exécutant les commandes suivantes sur la machine Unix (Solaris, Linux, etc.) -

$CATALINA_HOME/bin/startup.sh
 
or
 
/usr/local/apache-tomcat-5.5.29/bin/startup.sh

Après un démarrage réussi, les applications Web par défaut incluses avec Tomcat seront disponibles en visitant http://localhost:8080/.

Lors de l'exécution, vous recevrez la sortie suivante -

Vous trouverez de plus amples informations sur la configuration et l'exécution de Tomcat dans la documentation incluse ici, ainsi que sur le site Web de Tomcat - https://tomcat.apache.org/.

Tomcat peut être arrêté en exécutant les commandes suivantes sur la machine Windows -

%CATALINA_HOME%\bin\shutdown
or

C:\apache-tomcat-5.5.29\bin\shutdown

Tomcat peut être arrêté en exécutant les commandes suivantes sur une machine Unix (Solaris, Linux, etc.) -

$CATALINA_HOME/bin/shutdown.sh

or

/usr/local/apache-tomcat-5.5.29/bin/shutdown.sh

Configurer CLASSPATH

Étant donné que les servlets ne font pas partie de Java Platform, Standard Edition, vous devez identifier les classes de servlet auprès du compilateur.

Si vous utilisez Windows, vous devez mettre les lignes suivantes dans votre C:\autoexec.bat fichier.

set CATALINA = C:\apache-tomcat-5.5.29
set CLASSPATH = %CATALINA%\common\lib\jsp-api.jar;%CLASSPATH%

Alternativement, sur Windows NT/2000/XP, vous pouvez également cliquer avec le bouton droit sur My Computer, sélectionnez Properties, puis Advanced, puis Environment Variables. Ensuite, vous mettriez à jour la valeur CLASSPATH et appuyez sur le bouton OK.

Sous Unix (Solaris, Linux, etc.), si vous utilisez le shell C, vous mettriez les lignes suivantes dans votre .cshrc fichier.

setenv CATALINA = /usr/local/apache-tomcat-5.5.29
setenv CLASSPATH $CATALINA/common/lib/jsp-api.jar:$CLASSPATH

NOTE - En supposant que votre répertoire de développement est C:\JSPDev (Windows) ou /usr/JSPDev (Unix), alors vous devrez également ajouter ces répertoires dans CLASSPATH.

Le serveur Web a besoin d'un moteur JSP, c'est-à-dire d'un conteneur pour traiter les pages JSP. Le conteneur JSP est responsable de l'interception des demandes de pages JSP. Ce tutoriel utilise Apache qui a un conteneur JSP intégré pour prendre en charge le développement de pages JSP.

Un conteneur JSP fonctionne avec le serveur Web pour fournir l'environnement d'exécution et d'autres services dont une JSP a besoin. Il sait comprendre les éléments spéciaux qui font partie des JSP.

Le diagramme suivant montre la position du conteneur JSP et des fichiers JSP dans une application Web.

Traitement JSP

Les étapes suivantes expliquent comment le serveur Web crée la page Web à l'aide de JSP -

  • Comme pour une page normale, votre navigateur envoie une requête HTTP au serveur Web.

  • Le serveur Web reconnaît que la requête HTTP concerne une page JSP et la transmet à un moteur JSP. Cela se fait en utilisant l'URL ou la page JSP qui se termine par.jsp au lieu de .html.

  • Le moteur JSP charge la page JSP à partir du disque et la convertit en contenu de servlet. Cette conversion est très simple dans laquelle tout le texte du modèle est converti en instructions println () et tous les éléments JSP sont convertis en code Java. Ce code implémente le comportement dynamique correspondant de la page.

  • Le moteur JSP compile le servlet dans une classe exécutable et transmet la demande d'origine à un moteur de servlet.

  • Une partie du serveur Web appelée moteur de servlet charge la classe Servlet et l'exécute. Lors de l'exécution, le servlet produit une sortie au format HTML. La sortie est ensuite transmise au serveur Web par le moteur de servlet dans une réponse HTTP.

  • Le serveur Web transmet la réponse HTTP à votre navigateur en termes de contenu HTML statique.

  • Enfin, le navigateur Web gère la page HTML générée dynamiquement dans la réponse HTTP exactement comme s'il s'agissait d'une page statique.

Toutes les étapes mentionnées ci-dessus peuvent être vues dans le diagramme suivant -

En règle générale, le moteur JSP vérifie si un servlet pour un fichier JSP existe déjà et si la date de modification sur la JSP est antérieure à celle du servlet. Si le JSP est plus ancien que son servlet généré, le conteneur JSP suppose que le JSP n'a pas changé et que le servlet généré correspond toujours au contenu de la JSP. Cela rend le processus plus efficace qu'avec les autres langages de script (comme PHP) et donc plus rapide.

Donc, d'une certaine manière, une page JSP n'est en réalité qu'une autre façon d'écrire un servlet sans avoir à être un assistant de programmation Java. À l'exception de la phase de traduction, une page JSP est gérée exactement comme une servlet classique.

Dans ce chapitre, nous aborderons le cycle de vie de JSP. La clé pour comprendre les fonctionnalités de bas niveau de JSP est de comprendre le cycle de vie simple qu'elles suivent.

Un cycle de vie JSP est défini comme le processus depuis sa création jusqu'à sa destruction. Ceci est similaire à un cycle de vie de servlet avec une étape supplémentaire qui est nécessaire pour compiler une JSP en servlet.

Chemins suivis par JSP

Voici les chemins suivis par une JSP -

  • Compilation
  • Initialization
  • Execution
  • Cleanup

Les quatre phases principales du cycle de vie d'un JSP sont très similaires au cycle de vie d'un servlet. Les quatre phases ont été décrites ci-dessous -

Compilation JSP

Lorsqu'un navigateur demande une JSP, le moteur JSP vérifie d'abord s'il a besoin de compiler la page. Si la page n'a jamais été compilée ou si le JSP a été modifié depuis sa dernière compilation, le moteur JSP compile la page.

Le processus de compilation comprend trois étapes -

  • Analyse du JSP.
  • Transformer le JSP en servlet.
  • Compilation du servlet.

Initialisation JSP

Lorsqu'un conteneur charge une JSP, il appelle le jspInit()méthode avant de répondre aux demandes. Si vous devez effectuer une initialisation spécifique à JSP, remplacez lejspInit() méthode -

public void jspInit(){
   // Initialization code...
}

En règle générale, l'initialisation n'est effectuée qu'une seule fois et, comme avec la méthode d'initialisation du servlet, vous initialisez généralement les connexions à la base de données, ouvrez les fichiers et créez des tables de recherche dans la méthode jspInit.

Exécution JSP

Cette phase du cycle de vie JSP représente toutes les interactions avec les demandes jusqu'à ce que la JSP soit détruite.

Chaque fois qu'un navigateur demande une JSP et que la page a été chargée et initialisée, le moteur JSP appelle le _jspService() méthode dans le JSP.

La méthode _jspService () prend un HttpServletRequest Et un HttpServletResponse comme ses paramètres comme suit -

void _jspService(HttpServletRequest request, HttpServletResponse response) {
   // Service handling code...
}

le _jspService()La méthode d'une JSP est invoquée sur demande. Ceci est responsable de la génération de la réponse pour cette demande et cette méthode est également responsable de la génération des réponses aux sept méthodes HTTP, c'est-à-dire,GET, POST, DELETE, etc.

Nettoyage JSP

La phase de destruction du cycle de vie JSP représente le moment où une JSP est retirée de l'utilisation par un conteneur.

le jspDestroy()method est l'équivalent JSP de la méthode destroy pour les servlets. Remplacez jspDestroy lorsque vous devez effectuer un nettoyage, tel que la libération de connexions de base de données ou la fermeture de fichiers ouverts.

La méthode jspDestroy () a la forme suivante -

public void jspDestroy() {
   // Your cleanup code goes here.
}

Dans ce chapitre, nous discuterons de la syntaxe dans JSP. Nous comprendrons l'utilisation de base de la syntaxe simple (c'est-à-dire des éléments) impliqués dans le développement de JSP.

Éléments de JSP

Les éléments de JSP ont été décrits ci-dessous -

Le Scriptlet

Un scriptlet peut contenir n'importe quel nombre d'instructions de langage JAVA, de déclarations de variables ou de méthodes ou d'expressions valides dans le langage de script de page.

Voici la syntaxe de Scriptlet -

<% code fragment %>

Vous pouvez écrire l'équivalent XML de la syntaxe ci-dessus comme suit -

<jsp:scriptlet>
   code fragment
</jsp:scriptlet>

Tout texte, balises HTML ou éléments JSP que vous écrivez doit se trouver en dehors du scriptlet. Voici le premier exemple simple pour JSP -

<html>
   <head><title>Hello World</title></head>
   
   <body>
      Hello World!<br/>
      <%
         out.println("Your IP address is " + request.getRemoteAddr());
      %>
   </body>
</html>

NOTE - En supposant qu'Apache Tomcat est installé dans C: \ apache-tomcat-7.0.2 et que votre environnement est configuré selon le didacticiel de configuration de l'environnement.

Gardons le code ci-dessus dans le fichier JSP hello.jsp et mettez ce fichier dans C:\apache-tomcat7.0.2\webapps\ROOTannuaire. Parcourir le même en utilisant l'URLhttp://localhost:8080/hello.jsp. Le code ci-dessus générera le résultat suivant -

Déclarations JSP

Une déclaration déclare une ou plusieurs variables ou méthodes que vous pouvez utiliser dans le code Java ultérieurement dans le fichier JSP. Vous devez déclarer la variable ou la méthode avant de l'utiliser dans le fichier JSP.

Voici la syntaxe des déclarations JSP -

<%! declaration; [ declaration; ]+ ... %>

Vous pouvez écrire l'équivalent XML de la syntaxe ci-dessus comme suit -

<jsp:declaration>
   code fragment
</jsp:declaration>

Voici un exemple de déclarations JSP -

<%! int i = 0; %> 
<%! int a, b, c; %> 
<%! Circle a = new Circle(2.0); %>

Expression JSP

Un élément d'expression JSP contient une expression de langage de script qui est évaluée, convertie en chaîne et insérée là où l'expression apparaît dans le fichier JSP.

Étant donné que la valeur d'une expression est convertie en chaîne, vous pouvez utiliser une expression dans une ligne de texte, qu'elle soit ou non balisée avec HTML, dans un fichier JSP.

L'élément expression peut contenir toute expression valide selon la spécification du langage Java, mais vous ne pouvez pas utiliser de point-virgule pour terminer une expression.

Voici la syntaxe de l'expression JSP -

<%= expression %>

Vous pouvez écrire l'équivalent XML de la syntaxe ci-dessus comme suit -

<jsp:expression>
   expression
</jsp:expression>

L'exemple suivant montre une expression JSP -

<html> 
   <head><title>A Comment Test</title></head> 
   
   <body>
      <p>Today's date: <%= (new java.util.Date()).toLocaleString()%></p>
   </body> 
</html>

Le code ci-dessus générera le résultat suivant -

Today's date: 11-Sep-2010 21:24:25

Commentaires JSP

Le commentaire JSP marque le texte ou les instructions que le conteneur JSP doit ignorer. Un commentaire JSP est utile lorsque vous souhaitez masquer ou "commenter" une partie de votre page JSP.

Voici la syntaxe des commentaires JSP -

<%-- This is JSP comment --%>

L'exemple suivant montre les commentaires JSP -

<html> 
   <head><title>A Comment Test</title></head> 
   
   <body> 
      <h2>A Test of Comments</h2> 
      <%-- This comment will not be visible in the page source --%> 
   </body> 
</html>

Le code ci-dessus générera le résultat suivant -

A Test of Comments

Il existe un petit nombre de constructions spéciales que vous pouvez utiliser dans divers cas pour insérer des commentaires ou des caractères qui seraient autrement traités spécialement. Voici un résumé -

S.No. Syntaxe et objectif
1

<%-- comment --%>

Un commentaire JSP. Ignoré par le moteur JSP.

2

<!-- comment -->

Un commentaire HTML. Ignoré par le navigateur.

3

<\%

Représente statique <% littéral.

4

%\>

Représente statique%> littéral.

5

\'

Un guillemet simple dans un attribut qui utilise des guillemets simples.

6

\"

Un guillemet double dans un attribut qui utilise des guillemets doubles.

Directives JSP

Une directive JSP affecte la structure globale de la classe de servlet. Il a généralement la forme suivante -

<%@ directive attribute="value" %>

Il existe trois types de balise directive -

S.No. Directive et description
1

<%@ page ... %>

Définit les attributs dépendant de la page, tels que le langage de script, la page d'erreur et les exigences de mise en mémoire tampon.

2

<%@ include ... %>

Inclut un fichier pendant la phase de traduction.

3

<%@ taglib ... %>

Déclare une bibliothèque de balises, contenant des actions personnalisées, utilisées dans la page

Nous expliquerions la directive JSP dans un chapitre séparé JSP - Directives

Actions JSP

Utilisation des actions JSP constructsdans la syntaxe XML pour contrôler le comportement du moteur de servlet. Vous pouvez insérer dynamiquement un fichier, réutiliser des composants JavaBeans, transférer l'utilisateur vers une autre page ou générer du HTML pour le plugin Java.

Il n'y a qu'une seule syntaxe pour l'élément Action, car il est conforme à la norme XML -

<jsp:action_name attribute="value" />

Les éléments d'action sont essentiellement des fonctions prédéfinies. Le tableau suivant répertorie les actions JSP disponibles -

S.No. Syntaxe et objectif
1

jsp:include

Inclut un fichier au moment où la page est demandée.

2

jsp:useBean

Recherche ou instancie un JavaBean.

3

jsp:setProperty

Définit la propriété d'un JavaBean.

4

jsp:getProperty

Insère la propriété d'un JavaBean dans la sortie.

5

jsp:forward

Transfère le demandeur vers une nouvelle page.

6

jsp:plugin

Génère un code spécifique au navigateur qui crée une balise OBJECT ou EMBED pour le plugin Java.

sept

jsp:element

Définit les éléments XML de manière dynamique.

8

jsp:attribute

Définit l'attribut de l'élément XML défini dynamiquement.

9

jsp:body

Définit le corps de l'élément XML défini dynamiquement.

dix

jsp:text

Utilisé pour écrire du texte de modèle dans des pages et des documents JSP.

Nous expliquerions les actions JSP dans un chapitre séparé JSP - Actions

Objets implicites JSP

JSP prend en charge neuf variables définies automatiquement, également appelées objets implicites. Ces variables sont -

S.No. Objet et description
1

request

C'est le HttpServletRequest objet associé à la demande.

2

response

C'est le HttpServletResponse objet associé à la réponse au client.

3

out

C'est le PrintWriter objet utilisé pour envoyer la sortie au client.

4

session

C'est le HttpSession objet associé à la demande.

5

application

C'est le ServletContext objet associé au contexte d'application.

6

config

C'est le ServletConfig objet associé à la page.

sept

pageContext

Cela encapsule l'utilisation de fonctionnalités spécifiques au serveur telles que des performances plus élevées JspWriters.

8

page

Ceci est simplement un synonyme de this, et est utilisé pour appeler les méthodes définies par la classe de servlet traduite.

9

Exception

le Exception object permet d'accéder aux données d'exception par la JSP désignée.

Nous expliquerions les objets implicites JSP dans un chapitre séparé JSP - Objets implicites .

Déclarations de flux de contrôle

Vous pouvez utiliser toutes les API et blocs de construction de Java dans votre programmation JSP, y compris les déclarations de prise de décision, les boucles, etc.

Déclarations décisionnelles

le if...else block commence comme un Scriptlet ordinaire, mais le Scriptlet est fermé à chaque ligne avec du texte HTML inclus entre les balises Scriptlet.

<%! int day = 3; %> 
<html> 
   <head><title>IF...ELSE Example</title></head> 
   
   <body>
      <% if (day == 1 || day == 7) { %>
         <p> Today is weekend</p>
      <% } else { %>
         <p> Today is not weekend</p>
      <% } %>
   </body> 
</html>

Le code ci-dessus générera le résultat suivant -

Today is not weekend

Maintenant, regardez ce qui suit switch...case bloc qui a été écrit un peu différemment en utilisant out.println() et à l'intérieur des Scriptletas -

<%! int day = 3; %> 
<html> 
   <head><title>SWITCH...CASE Example</title></head> 
   
   <body>
      <% 
         switch(day) {
            case 0:
               out.println("It\'s Sunday.");
               break;
            case 1:
               out.println("It\'s Monday.");
               break;
            case 2:
               out.println("It\'s Tuesday.");
               break;
            case 3:
               out.println("It\'s Wednesday.");
               break;
            case 4:
               out.println("It\'s Thursday.");
               break;
            case 5:
               out.println("It\'s Friday.");
               break;
            default:
               out.println("It's Saturday.");
         }
      %>
   </body> 
</html>

Le code ci-dessus générera le résultat suivant -

It's Wednesday.

Déclarations de boucle

Vous pouvez également utiliser trois types de base de blocs en boucle en Java: for, while, and do…while blocs dans votre programmation JSP.

Regardons ce qui suit for exemple de boucle -

<%! int fontSize; %> 
<html> 
   <head><title>FOR LOOP Example</title></head> 
   
   <body>
      <%for ( fontSize = 1; fontSize <= 3; fontSize++){ %>
         <font color = "green" size = "<%= fontSize %>">
            JSP Tutorial
      </font><br />
      <%}%>
   </body> 
</html>

Le code ci-dessus générera le résultat suivant -

JSP Tutorial 
JSP Tutorial
JSP Tutorial

L'exemple ci-dessus peut être écrit en utilisant le while boucle comme suit -

<%! int fontSize; %> 
<html> 
   <head><title>WHILE LOOP Example</title></head> 
   
   <body>
      <%while ( fontSize <= 3){ %>
         <font color = "green" size = "<%= fontSize %>">
            JSP Tutorial
         </font><br />
         <%fontSize++;%>
      <%}%>
   </body> 
</html>

Le code ci-dessus générera le résultat suivant -

JSP Tutorial 

 JSP Tutorial 

 JSP Tutorial

Opérateurs JSP

JSP prend en charge tous les opérateurs logiques et arithmétiques pris en charge par Java. Le tableau suivant répertorie tous les opérateurs avec la priorité la plus élevée apparaissent en haut du tableau, ceux avec les plus faibles apparaissent en bas.

Dans une expression, les opérateurs de priorité supérieure seront évalués en premier.

Catégorie Opérateur Associativité
Postfix () []. (opérateur point) De gauche à droite
Unaire ++ - -! ~ De droite à gauche
Multiplicatif * /% De gauche à droite
Additif + - De gauche à droite
Décalage >> >>> << De gauche à droite
Relationnel >> = <<= De gauche à droite
Égalité ==! = De gauche à droite
ET au niveau du bit & De gauche à droite
XOR au niveau du bit ^ De gauche à droite
OU au niveau du bit | De gauche à droite
ET logique && De gauche à droite
OU logique || De gauche à droite
Conditionnel ?: De droite à gauche
Affectation = + = - = * = / =% = >> = << = & = ^ = | = De droite à gauche
Virgule , De gauche à droite

Littéraux JSP

Le langage d'expression JSP définit les littéraux suivants -

  • Boolean - vrai et faux

  • Integer - comme en Java

  • Floating point - comme en Java

  • String- avec des guillemets simples et doubles; "est échappé comme \", 'est échappé comme \' et \ est échappé comme \\.

  • Null - nul

Dans ce chapitre, nous discuterons des directives dans JSP. Ces directives fournissent des instructions et des instructions au conteneur, lui indiquant comment gérer certains aspects du traitement JSP.

Une directive JSP affecte la structure globale de la classe de servlet. Il a généralement la forme suivante -

<%@ directive attribute = "value" %>

Les directives peuvent avoir un certain nombre d'attributs que vous pouvez lister sous forme de paires clé-valeur et séparés par des virgules.

Les espaces entre le symbole @ et le nom de la directive, et entre le dernier attribut et la fermeture%>, sont facultatifs.

Il existe trois types de balise directive -

S.No. Directive et description
1

<%@ page ... %>

Définit les attributs dépendant de la page, tels que le langage de script, la page d'erreur et les exigences de mise en mémoire tampon.

2

<%@ include ... %>

Inclut un fichier pendant la phase de traduction.

3

<%@ taglib ... %>

Déclare une bibliothèque de balises, contenant des actions personnalisées, utilisées dans la page

JSP - La directive page

le pagedirective est utilisée pour fournir des instructions au conteneur. Ces instructions concernent la page JSP actuelle. Vous pouvez coder des directives de page n'importe où dans votre page JSP. Par convention, les directives de page sont codées en haut de la page JSP.

Voici la syntaxe de base de la directive de page -

<%@ page attribute = "value" %>

Vous pouvez écrire l'équivalent XML de la syntaxe ci-dessus comme suit -

<jsp:directive.page attribute = "value" />

Les attributs

Le tableau suivant répertorie les attributs associés à la directive de page -

S.No. Attribut et objectif
1

buffer

Spécifie un modèle de mise en mémoire tampon pour le flux de sortie.

2

autoFlush

Contrôle le comportement du tampon de sortie du servlet.

3

contentType

Définit le schéma de codage des caractères.

4

errorPage

Définit l'URL d'un autre JSP qui signale les exceptions d'exécution non vérifiées Java.

5

isErrorPage

Indique si cette page JSP est une URL spécifiée par l'attribut errorPage d'une autre page JSP.

6

extends

Spécifie une superclasse que le servlet généré doit étendre.

sept

import

Spécifie une liste de packages ou de classes à utiliser dans la JSP, comme le fait l'instruction d'importation Java pour les classes Java.

8

info

Définit une chaîne accessible avec le servlet getServletInfo() méthode.

9

isThreadSafe

Définit le modèle de thread pour le servlet généré.

dix

language

Définit le langage de programmation utilisé dans la page JSP.

11

session

Spécifie si la page JSP participe ou non aux sessions HTTP

12

isELIgnored

Spécifie si l'expression EL dans la page JSP sera ignorée ou non.

13

isScriptingEnabled

Détermine si les éléments de script sont autorisés à être utilisés.

Consultez la page Directive pour plus de détails sur tous les attributs ci-dessus .

La directive inclure

le includedirective est utilisée pour inclure un fichier pendant la phase de traduction. Cette directive indique au conteneur de fusionner le contenu d'autres fichiers externes avec la JSP actuelle pendant la phase de traduction. Vous pouvez coder leinclude directives n'importe où dans votre page JSP.

La forme générale d'utilisation de cette directive est la suivante -

<%@ include file = "relative url" >

Le nom de fichier dans la directive include est en fait une URL relative. Si vous spécifiez simplement un nom de fichier sans chemin associé, le compilateur JSP suppose que le fichier se trouve dans le même répertoire que votre JSP.

Vous pouvez écrire l'équivalent XML de la syntaxe ci-dessus comme suit -

<jsp:directive.include file = "relative url" />

Pour plus de détails sur la directive d'inclusion, consultez la directive Inclure .

La directive taglib

L'API JavaServer Pages vous permet de définir des balises JSP personnalisées qui ressemblent à des balises HTML ou XML et une bibliothèque de balises est un ensemble de balises définies par l'utilisateur qui implémentent un comportement personnalisé.

le taglib La directive déclare que votre page JSP utilise un ensemble de balises personnalisées, identifie l'emplacement de la bibliothèque et fournit des moyens pour identifier les balises personnalisées dans votre page JSP.

La directive taglib suit la syntaxe donnée ci-dessous -

<%@ taglib uri="uri" prefix = "prefixOfTag" >

Ici le uri La valeur d'attribut se résout en un emplacement que le conteneur comprend et le prefix L'attribut informe un conteneur quels bits de balisage sont des actions personnalisées.

Vous pouvez écrire l'équivalent XML de la syntaxe ci-dessus comme suit -

<jsp:directive.taglib uri = "uri" prefix = "prefixOfTag" />

Pour plus de détails sur la directive taglib, consultez la directive Taglib .

Dans ce chapitre, nous discuterons des actions dans JSP. Ces actions utilisent des constructions dans la syntaxe XML pour contrôler le comportement du moteur de servlet. Vous pouvez insérer dynamiquement un fichier, réutiliser des composants JavaBeans, transférer l'utilisateur vers une autre page ou générer du HTML pour le plugin Java.

Il n'y a qu'une seule syntaxe pour l'élément Action, car il est conforme à la norme XML -

<jsp:action_name attribute = "value" />

Les éléments d'action sont essentiellement des fonctions prédéfinies. Le tableau suivant répertorie les actions JSP disponibles -

S.No. Syntaxe et objectif
1

jsp:include

Inclut un fichier au moment où la page est demandée.

2

jsp:useBean

Recherche ou instancie un JavaBean.

3

jsp:setProperty

Définit la propriété d'un JavaBean.

4

jsp:getProperty

Insère la propriété d'un JavaBean dans la sortie.

5

jsp:forward

Transfère le demandeur vers une nouvelle page.

6

jsp:plugin

Génère un code spécifique au navigateur qui crée une balise OBJECT ou EMBED pour le plugin Java.

sept

jsp:element

Définit les éléments XML de manière dynamique.

8

jsp:attribute

Définit l'attribut de l'élément XML défini dynamiquement.

9

jsp:body

Définit le corps de l'élément XML défini dynamiquement.

dix

jsp:text

Utilisé pour écrire du texte de modèle dans des pages et des documents JSP.

Attributs communs

Il existe deux attributs communs à tous les éléments Action: le id attribut et le scope attribut.

Attribut ID

L'attribut id identifie de manière unique l'élément Action et permet à l'action d'être référencée dans la page JSP. Si l'action crée une instance d'un objet, la valeur de l'id peut être utilisée pour le référencer via l'objet implicite PageContext.

Attribut d'étendue

Cet attribut identifie le cycle de vie de l'élément Action. L'attribut id et l'attribut scope sont directement liés, car l'attribut scope détermine la durée de vie de l'objet associé à l'id. L'attribut scope a quatre valeurs possibles:(a) page, (b)request, (c)session, et (d) application.

L'action <jsp: include>

Cette action vous permet d'insérer des fichiers dans la page en cours de génération. La syntaxe ressemble à ceci -

<jsp:include page = "relative URL" flush = "true" />

Contrairement au include directive, qui insère le fichier au moment où la page JSP est traduite en servlet, cette action insère le fichier au moment où la page est demandée.

Le tableau suivant répertorie les attributs associés à l'action d'inclusion -

S.No. Attribut et description
1

page

L'URL relative de la page à inclure.

2

flush

L'attribut booléen détermine si la ressource incluse a sa mémoire tampon vidée avant d'être incluse.

Exemple

Définissons les deux fichiers suivants (a)date.jsp et (b) main.jsp comme suit -

Voici le contenu de la date.jsp fichier -

<p>Today's date: <%= (new java.util.Date()).toLocaleString()%></p>

Voici le contenu de la main.jsp fichier -

<html>
   <head>
      <title>The include Action Example</title>
   </head>
   
   <body>
      <center>
         <h2>The include action Example</h2>
         <jsp:include page = "date.jsp" flush = "true" />
      </center>
   </body>
</html>

Gardons maintenant tous ces fichiers dans le répertoire racine et essayons d'accéder main.jsp. Vous recevrez la sortie suivante -

The include action Example

Today's date: 12-Sep-2010 14:54:22

L'action <jsp: useBean>

le useBeanl'action est assez polyvalente. Il recherche d'abord un objet existant en utilisant les variables id et scope. Si un objet n'est pas trouvé, il essaie alors de créer l'objet spécifié.

La façon la plus simple de charger un bean est la suivante -

<jsp:useBean id = "name" class = "package.class" />

Une fois qu'une classe de bean est chargée, vous pouvez utiliser jsp:setProperty et jsp:getProperty actions pour modifier et récupérer les propriétés du bean.

Le tableau suivant répertorie les attributs associés à l'action useBean -

S.No. Attribut et description
1

class

Désigne le nom complet du package du bean.

2

type

Spécifie le type de la variable qui fera référence à l'objet.

3

beanName

Donne le nom du bean tel que spécifié par la méthode instanciate () de la classe java.beans.Beans.

Parlons maintenant de la jsp:setProperty et le jsp:getProperty actions avant de donner un exemple valide lié à ces actions.

L'action <jsp: setProperty>

le setPropertyaction définit les propriétés d'un Bean. Le Bean doit avoir été préalablement défini avant cette action. Il existe deux méthodes de base pour utiliser l'action setProperty -

Vous pouvez utiliser jsp:setProperty après, mais en dehors d'un jsp:useBean élément, comme indiqué ci-dessous -

<jsp:useBean id = "myName" ... />
...
<jsp:setProperty name = "myName" property = "someProperty" .../>

Dans ce cas, le jsp:setProperty est exécuté indépendamment du fait qu'un nouveau bean ait été instancié ou qu'un bean existant ait été trouvé.

Un deuxième contexte dans lequel jsp: setProperty peut apparaître est à l'intérieur du corps d'un jsp:useBean élément, comme indiqué ci-dessous -

<jsp:useBean id = "myName" ... >
   ...
   <jsp:setProperty name = "myName" property = "someProperty" .../>
</jsp:useBean>

Ici, le jsp: setProperty est exécuté uniquement si un nouvel objet a été instancié, pas si un objet existant a été trouvé.

Le tableau suivant répertorie les attributs associés au setProperty action -

S.No. Attribut et description
1

name

Désigne le bean dont la propriété sera définie. Le Bean doit avoir été préalablement défini.

2

property

Indique la propriété que vous souhaitez définir. Une valeur de "*" signifie que tous les paramètres de requête dont les noms correspondent aux noms de propriété de bean seront passés aux méthodes de définition appropriées.

3

value

Valeur à affecter à la propriété donnée. La valeur du paramètre est null ou le paramètre n'existe pas, l'action setProperty est ignorée.

4

param

L'attribut param est le nom du paramètre de demande dont la propriété doit recevoir la valeur. Vous ne pouvez pas utiliser à la fois value et param, mais il est permis d'utiliser ni l'un ni l'autre.

L'action <jsp: getProperty>

le getProperty action est utilisée pour récupérer la valeur d'une propriété donnée et la convertit en chaîne, et enfin l'insère dans la sortie.

L'action getProperty n'a que deux attributs, tous deux obligatoires. La syntaxe de l'action getProperty est la suivante -

<jsp:useBean id = "myName" ... />
...
<jsp:getProperty name = "myName" property = "someProperty" .../>

Le tableau suivant répertorie les attributs requis associés au getProperty action -

S.No. Attribut et description
1

name

Le nom du Bean qui a une propriété à récupérer. Le Bean doit avoir été préalablement défini.

2

property

L'attribut de propriété est le nom de la propriété Bean à récupérer.

Exemple

Définissons un bean test qui sera ensuite utilisé dans notre exemple -

/* File: TestBean.java */
package action;
 
public class TestBean {
   private String message = "No message specified";
 
   public String getMessage() {
      return(message);
   }
   public void setMessage(String message) {
      this.message = message;
   }
}

Compilez le code ci-dessus dans le fichier généré TestBean.class et assurez-vous que vous avez copié le TestBean.class dans C:\apache-tomcat-7.0.2\webapps\WEB-INF\classes\action dossier et le CLASSPATH variable doit également être définie sur ce dossier -

Maintenant, utilisez le code suivant dans main.jspfichier. Cela charge le bean et définit / obtient un simple paramètre String -

<html>
   
   <head>
      <title>Using JavaBeans in JSP</title>
   </head>
   
   <body>
      <center>
         <h2>Using JavaBeans in JSP</h2>
         <jsp:useBean id = "test" class = "action.TestBean" />
         <jsp:setProperty name = "test"  property = "message" 
            value = "Hello JSP..." />
            
         <p>Got message....</p>
         <jsp:getProperty name = "test" property = "message" />
      </center>
   </body>
</html>

Essayons maintenant d'accéder main.jsp, il afficherait le résultat suivant -

Using JavaBeans in JSP

Got message.... Hello JSP...

L'action <jsp: forward>

le forward action met fin à l'action de la page actuelle et transmet la demande à une autre ressource telle qu'une page statique, une autre page JSP ou un servlet Java.

Voici la syntaxe du forward action -

<jsp:forward page = "Relative URL" />

Le tableau suivant répertorie les attributs requis associés à l'action de transfert -

S.No. Attribut et description
1

page

Doit consister en une URL relative d'une autre ressource telle qu'une page statique, une autre page JSP ou un servlet Java.

Exemple

Réutilisons les deux fichiers suivants (a) date.jsp et (b) main.jsp comme suit -

Voici le contenu de la date.jsp fichier -

<p>Today's date: <%= (new java.util.Date()).toLocaleString()%></p>

Voici le contenu de la main.jsp fichier -

<html>
   <head>
      <title>The include Action Example</title>
   </head>
   
   <body>
      <center>
         <h2>The include action Example</h2>
         <jsp:forward page = "date.jsp" />
      </center>
   </body>
</html>

Gardons maintenant tous ces fichiers dans le répertoire racine et essayons d'accéder main.jsp. Cela afficherait le résultat quelque chose comme ci-dessous.

Ici, il a supprimé le contenu de la page principale et affiché le contenu de la page transférée uniquement.

Today's date: 12-Sep-2010 14:54:22

L'action <jsp: plugin>

le pluginL'action est utilisée pour insérer des composants Java dans une page JSP. Il détermine le type de navigateur et insère le<object> ou <embed> balises au besoin.

Si le plugin nécessaire n'est pas présent, il télécharge le plugin puis exécute le composant Java. Le composant Java peut être une applet ou un JavaBean.

L'action du plugin a plusieurs attributs qui correspondent aux balises HTML courantes utilisées pour formater les composants Java. le<param> L'élément peut également être utilisé pour envoyer des paramètres à l'applet ou au bean.

Voici la syntaxe typique d'utilisation de l'action du plugin -

<jsp:plugin type = "applet" codebase = "dirname" code = "MyApplet.class"
   width = "60" height = "80">
   <jsp:param name = "fontcolor" value = "red" />
   <jsp:param name = "background" value = "black" />
 
   <jsp:fallback>
      Unable to initialize Java Plugin
   </jsp:fallback>
 
</jsp:plugin>

Vous pouvez essayer cette action en utilisant une applet si vous êtes intéressé. Un nouvel élément, le<fallback> element, peut être utilisé pour spécifier une chaîne d'erreur à envoyer à l'utilisateur en cas de défaillance du composant.

The <jsp:element> Action

The <jsp:attribute> Action

The <jsp:body> Action

le <jsp:element>, <jsp:attribute> et <jsp:body>Les actions sont utilisées pour définir dynamiquement des éléments XML. Le mot dynamiquement est important, car il signifie que les éléments XML peuvent être générés au moment de la demande plutôt que de manière statique au moment de la compilation.

Voici un exemple simple pour définir dynamiquement des éléments XML -

<%@page language = "java" contentType = "text/html"%>
<html xmlns = "http://www.w3c.org/1999/xhtml"
   xmlns:jsp = "http://java.sun.com/JSP/Page">
   
   <head><title>Generate XML Element</title></head>
   
   <body>
      <jsp:element name = "xmlElement">
         <jsp:attribute name = "xmlElementAttr">
            Value for the attribute
         </jsp:attribute>
         
         <jsp:body>
            Body for XML element
         </jsp:body>
      
      </jsp:element>
   </body>
</html>

Cela produirait le code HTML suivant au moment de l'exécution -

<html xmlns = "http://www.w3c.org/1999/xhtml" xmlns:jsp = "http://java.sun.com/JSP/Page">
   <head><title>Generate XML Element</title></head>
   
   <body>
      <xmlElement xmlElementAttr = "Value for the attribute">
         Body for XML element
      </xmlElement>
   </body>
</html>

L'action <jsp: text>

le <jsp:text>l'action peut être utilisée pour écrire le texte du modèle dans les pages et documents JSP. Voici la syntaxe simple de cette action -

<jsp:text>Template data</jsp:text>

Le corps du modèle ne peut pas contenir d'autres éléments; il ne peut contenir que du texte et des expressions EL (Remarque - Les expressions EL sont expliquées dans un chapitre suivant). Notez que dans les fichiers XML, vous ne pouvez pas utiliser d'expressions telles que${whatever > 0}, car les signes supérieurs à sont illégaux. Utilisez plutôt legt forme, telle que ${whatever gt 0} ou une alternative consiste à intégrer la valeur dans un CDATA section.

<jsp:text><![CDATA[<br>]]></jsp:text>

Si vous devez inclure un DOCTYPE déclaration, par exemple pour XHTML, vous devez également utiliser le <jsp:text> élément comme suit -

<jsp:text><![CDATA[<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
   "DTD/xhtml1-strict.dtd">]]></jsp:text>

   <head><title>jsp:text action</title></head>
   
   <body>
      <books><book><jsp:text>  
         Welcome to JSP Programming
      </jsp:text></book></books>
   </body>
</html>

Essayez l'exemple ci-dessus avec et sans <jsp:text> action.

Dans ce chapitre, nous aborderons les objets implicites dans JSP. Ces objets sont les objets Java que le conteneur JSP met à la disposition des développeurs dans chaque page et le développeur peut les appeler directement sans être explicitement déclaré. Les objets implicites JSP sont également appeléspre-defined variables.

Le tableau suivant répertorie les neuf objets implicites pris en charge par JSP -

S.No. Objet et description
1

request

C'est le HttpServletRequest objet associé à la demande.

2

response

C'est le HttpServletResponse objet associé à la réponse au client.

3

out

C'est le PrintWriter objet utilisé pour envoyer la sortie au client.

4

session

C'est le HttpSession objet associé à la demande.

5

application

C'est le ServletContext objet associé au contexte d'application.

6

config

C'est le ServletConfig objet associé à la page.

sept

pageContext

Cela encapsule l'utilisation de fonctionnalités spécifiques au serveur telles que des performances plus élevées JspWriters.

8

page

Ceci est simplement un synonyme de this, et est utilisé pour appeler les méthodes définies par la classe de servlet traduite.

9

Exception

le Exception object permet d'accéder aux données d'exception par la JSP désignée.

L'objet de requête

L'objet de requête est une instance d'un javax.servlet.http.HttpServletRequestobjet. Chaque fois qu'un client demande une page, le moteur JSP crée un nouvel objet pour représenter cette demande.

L'objet de requête fournit des méthodes pour obtenir les informations d'en-tête HTTP, y compris les données de formulaire, les cookies, les méthodes HTTP, etc.

Nous pouvons couvrir un ensemble complet de méthodes associées à l'objet request dans un chapitre suivant - JSP - Client Request .

L'objet de réponse

L'objet de réponse est une instance d'un javax.servlet.http.HttpServletResponseobjet. Tout comme le serveur crée l'objet de requête, il crée également un objet pour représenter la réponse au client.

L'objet de réponse définit également les interfaces qui traitent de la création de nouveaux en-têtes HTTP. Grâce à cet objet, le programmeur JSP peut ajouter de nouveaux cookies ou horodatages, codes d'état HTTP, etc.

Nous couvrirons un ensemble complet de méthodes associées à l'objet de réponse dans un chapitre suivant - JSP - Réponse du serveur .

L'objet out

L'objet implicite out est une instance d'un javax.servlet.jsp.JspWriter objet et est utilisé pour envoyer du contenu dans une réponse.

L'objet JspWriter initial est instancié différemment selon que la page est mise en mémoire tampon ou non. La mise en mémoire tampon peut être facilement désactivée en utilisant lebuffered = 'false' attribut de la directive de page.

L'objet JspWriter contient la plupart des mêmes méthodes que le java.io.PrintWriterclasse. Cependant, JspWriter a quelques méthodes supplémentaires conçues pour gérer la mise en mémoire tampon. Contrairement à l'objet PrintWriter, JspWriter lanceIOExceptions.

Le tableau suivant répertorie les méthodes importantes que nous utiliserons pour écrire boolean char, int, double, object, String, etc.

S.No. Méthode et description
1

out.print(dataType dt)

Imprimer une valeur de type de données

2

out.println(dataType dt)

Imprimez une valeur de type de données puis terminez la ligne avec un caractère de nouvelle ligne.

3

out.flush()

Rincez le flux.

L'objet de session

L'objet session est une instance de javax.servlet.http.HttpSession et se comporte exactement de la même manière que les objets de session se comportent sous les servlets Java.

L'objet de session est utilisé pour suivre la session client entre les demandes client. Nous couvrirons l'utilisation complète de l'objet session dans un chapitre suivant - JSP - Suivi de session .

L'objet d'application

L'objet application est un wrapper direct autour du ServletContext objet pour le servlet généré et en réalité une instance d'un javax.servlet.ServletContext objet.

Cet objet est une représentation de la page JSP tout au long de son cycle de vie. Cet objet est créé lorsque la page JSP est initialisée et sera supprimé lorsque la page JSP sera supprimée par lejspDestroy() méthode.

En ajoutant un attribut à l'application, vous pouvez vous assurer que tous les fichiers JSP qui composent votre application Web y ont accès.

Nous allons vérifier l'utilisation de l'objet Application dans le chapitre JSP - Hits Counter .

L'objet de configuration

L'objet config est une instanciation de javax.servlet.ServletConfig et est une enveloppe directe autour du ServletConfig objet pour le servlet généré.

Cet objet permet au programmeur JSP d'accéder aux paramètres d'initialisation du servlet ou du moteur JSP tels que les chemins ou les emplacements de fichiers, etc.

Le suivant config est la seule que vous puissiez utiliser, et son utilisation est triviale -

config.getServletName();

Cela renvoie le nom du servlet, qui est la chaîne contenue dans le <servlet-name> élément défini dans le WEB-INF\web.xml fichier.

L'objet pageContext

L'objet pageContext est une instance d'un javax.servlet.jsp.PageContextobjet. L'objet pageContext est utilisé pour représenter la page JSP entière.

Cet objet est conçu comme un moyen d'accéder aux informations sur la page tout en évitant la plupart des détails d'implémentation.

Cet objet stocke des références aux objets de demande et de réponse pour chaque demande. leapplication, config, session, et les objets out sont dérivés en accédant aux attributs de cet objet.

L'objet pageContext contient également des informations sur les directives émises sur la page JSP, y compris les informations de mise en mémoire tampon, errorPageURL et l'étendue de la page.

La classe PageContext définit plusieurs champs, dont PAGE_SCOPE, REQUEST_SCOPE, SESSION_SCOPE, et APPLICATION_SCOPE, qui identifient les quatre portées. Il prend également en charge plus de 40 méthodes, dont environ la moitié sont héritées dujavax.servlet.jsp.JspContext class.

L'une des méthodes importantes est removeAttribute. Cette méthode accepte un ou deux arguments. Par exemple,pageContext.removeAttribute ("attrName") supprime l'attribut de toutes les étendues, tandis que le code suivant le supprime uniquement de l'étendue de la page -

pageContext.removeAttribute("attrName", PAGE_SCOPE);

L'utilisation de pageContext peut être vérifiée dans le chapitre JSP - Téléchargement de fichiers .

L'objet de la page

Cet objet est une référence réelle à l'instance de la page. Il peut être considéré comme un objet qui représente la page JSP entière.

L'objet de page est vraiment un synonyme direct de this objet.

L'objet d'exception

L'objet exception est un wrapper contenant l'exception levée à partir de la page précédente. Il est généralement utilisé pour générer une réponse appropriée à la condition d'erreur.

Nous couvrirons l'utilisation complète de cet objet dans le chapitre JSP - Gestion des exceptions .

Dans ce chapitre, nous discuterons de la demande client dans JSP. Lorsqu'un navigateur demande une page Web, il envoie beaucoup d'informations au serveur Web. Ces informations ne peuvent pas être lues directement car ces informations voyagent dans le cadre de l'en-tête de la requête HTTP. Vous pouvez consulter le protocole HTTP pour plus d'informations à ce sujet.

Le tableau suivant répertorie les informations d'en-tête importantes provenant du navigateur. Ces informations sont fréquemment utilisées dans la programmation Web -

S.No. En-tête et description
1

Accept

Cet en-tête spécifie le MIMEtypes que le navigateur ou d'autres clients peuvent gérer. Valeurs deimage/png ou image/jpeg sont les deux possibilités les plus courantes.

2

Accept-Charset

Cet en-tête spécifie les jeux de caractères que le navigateur peut utiliser pour afficher les informations. Par exemple,ISO-8859-1.

3

Accept-Encoding

Cet en-tête spécifie les types d'encodages que le navigateur sait gérer. Valeurs degzip ou compress sont les deux possibilités les plus courantes.

4

Accept-Language

Cet en-tête spécifie les langues préférées du client au cas où le servlet peut produire des résultats dans plusieurs langues. Par exempleen, en-us, ru, etc.

5

Authorization

Cet en-tête est utilisé par les clients pour s'identifier lorsqu'ils accèdent à des pages Web protégées par mot de passe.

6

Connection

Cet en-tête indique si le client peut gérer les connexions HTTP persistantes. Les connexions persistantes permettent au client ou à un autre navigateur de récupérer plusieurs fichiers avec une seule demande. Une valeur deKeep-Alive signifie que des connexions persistantes doivent être utilisées.

sept

Content-Length

Cet en-tête s'applique uniquement à POST demande et donne la taille des données POST en octets.

8

Cookie

Cet en-tête renvoie les cookies aux serveurs qui les ont précédemment envoyés au navigateur.

9

Host

Cet en-tête spécifie l'hôte et le port comme indiqué dans l'URL d'origine.

dix

If-Modified-Since

Cet en-tête indique que le client veut la page uniquement si elle a été modifiée après la date spécifiée. Le serveur envoie un code, 304 ce qui signifieNot Modified en-tête si aucun résultat plus récent n'est disponible.

11

If-Unmodified-Since

Cet en-tête est l'inverse de If-Modified-Since; il spécifie que l'opération ne doit réussir que si le document est plus ancien que la date spécifiée.

12

Referer

Cet en-tête indique l'URL des pages Web de référence. Par exemple, si vous êtes sur la page Web 1 et cliquez sur un lien vers la page Web 2, l'URL de la page Web 1 est incluse dans l'en-tête Referer lorsque le navigateur demande la page Web 2.

13

User-Agent

Cet en-tête identifie le navigateur ou un autre client effectuant la demande et peut être utilisé pour renvoyer différents contenus à différents types de navigateurs.

L'objet HttpServletRequest

L'objet de requête est une instance d'un javax.servlet.http.HttpServletRequestobjet. Chaque fois qu'un client demande une page, le moteur JSP crée un nouvel objet pour représenter cette demande.

L'objet de requête fournit des méthodes pour obtenir des informations d'en-tête HTTP, notamment form data, cookies, HTTP methods, etc.

Le tableau suivant répertorie les méthodes importantes qui peuvent être utilisées pour lire l'en-tête HTTP dans votre programme JSP. Ces méthodes sont disponibles avec l' objet HttpServletRequest qui représente la demande du client au serveur Web.

S.No. Méthode et description
1

Cookie[] getCookies()

Renvoie un tableau contenant tous les objets Cookie que le client a envoyés avec cette demande.

2

Enumeration getAttributeNames()

Renvoie une énumération contenant les noms des attributs disponibles pour cette demande.

3

Enumeration getHeaderNames()

Renvoie une énumération de tous les noms d'en-tête que contient cette demande.

4

Enumeration getParameterNames()

Renvoie une énumération d'objets String contenant les noms des paramètres contenus dans cette requête.

5

HttpSession getSession()

Renvoie la session en cours associée à cette demande, ou si la demande n'a pas de session, en crée une.

6

HttpSession getSession(boolean create)

Renvoie la HttpSession actuelle associée à la demande this ou, s'il n'y a pas de session en cours et que create est true, renvoie une nouvelle session.

sept

Locale getLocale()

Renvoie les paramètres régionaux préférés dans lesquels le client acceptera le contenu, en fonction de l'en-tête Accept-Language.

8

Object getAttribute(String name)

Returns the value of the named attribute as an Object, or null if no attribute of the given name exists.

9

ServletInputStream getInputStream()

Retrieves the body of the request as binary data using a ServletInputStream.

10

String getAuthType()

Returns the name of the authentication scheme used to protect the servlet, for example, "BASIC" or "SSL," or null if the JSP was not protected.

11

String getCharacterEncoding()

Returns the name of the character encoding used in the body of this request.

12

String getContentType()

Returns the MIME type of the body of the request, or null if the type is not known.

13

String getContextPath()

Returns the portion of the request URI that indicates the context of the request.

14

String getHeader(String name)

Returns the value of the specified request header as a String.

15

String getMethod()

Returns the name of the HTTP method with which this request was made, for example, GET, POST, or PUT.

16

String getParameter(String name)

Returns the value of a request parameter as a String, or null if the parameter does not exist.

17

String getPathInfo()

Returns any extra path information associated with the URL the client sent when it made this request.

18

String getProtocol()

Returns the name and version of the protocol the request uses.

19

String getQueryString()

Returns the query string that is contained in the request URL after the path.

20

String getRemoteAddr()

Returns the Internet Protocol (IP) address of the client that sent the request.

21

String getRemoteHost()

Returns the fully qualified name of the client that sent the request.

22

String getRemoteUser()

Returns the login of the user making this request, if the user has been authenticated, or null if the user has not been authenticated.

23

String getRequestURI()

Returns the part of this request's URL from the protocol name up to the query string in the first line of the HTTP request.

24

String getRequestedSessionId()

Returns the session ID specified by the client.

25

String getServletPath()

Returns the part of this request's URL that calls the JSP.

26

String[] getParameterValues(String name)

Returns an array of String objects containing all of the values the given request parameter has, or null if the parameter does not exist.

27

boolean isSecure()

Returns a boolean indicating whether this request was made using a secure channel, such as HTTPS.

28

int getContentLength()

Returns the length, in bytes, of the request body and made available by the input stream, or -1 if the length is not known.

29

int getIntHeader(String name)

Returns the value of the specified request header as an int.

30

int getServerPort()

Returns the port number on which this request was received.

HTTP Header Request Example

Following is the example which uses getHeaderNames() method of HttpServletRequest to read the HTTP header information. This method returns an Enumeration that contains the header information associated with the current HTTP request.

Once we have an Enumeration, we can loop down the Enumeration in the standard manner. We will use the hasMoreElements() method to determine when to stop and the nextElement() method to get the name of each parameter name.

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>HTTP Header Request Example</title>
   </head>

   <body>
      <center>
         <h2>HTTP Header Request Example</h2>
         
         <table width = "100%" border = "1" align = "center">
            <tr bgcolor = "#949494">
               <th>Header Name</th>
               <th>Header Value(s)</th>
            </tr>
            <%
               Enumeration headerNames = request.getHeaderNames();
               while(headerNames.hasMoreElements()) {
                  String paramName = (String)headerNames.nextElement();
                  out.print("<tr><td>" + paramName + "</td>\n");
                  String paramValue = request.getHeader(paramName);
                  out.println("<td> " + paramValue + "</td></tr>\n");
               }
            %>
         </table>
      </center>
   
   </body>
</html>

Let us now put the above code in main.jsp and try to access it.

HTTP Header Request Example

Header Name Header Value(s)
accept */*
accept-language en-us
user-agent Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0; InfoPath.2; MS-RTC LM 8)
accept-encoding gzip, deflate
host localhost:8080
connection Keep-Alive
cache-control no-cache

You can try working on all the methods in a similar way.

In this chapter, we will discuss the Server Response in JSP. When a Web server responds to a HTTP request, the response typically consists of a status line, some response headers, a blank line, and the document. A typical response looks like this −

HTTP/1.1 200 OK
Content-Type: text/html
Header2: ...
...
HeaderN: ...
   (Blank Line)
<!doctype ...>

<html>
   <head>...</head>
   <body>
      ...
   </body>
</html>

The status line consists of the HTTP version (HTTP/1.1 in the example), a status code (200 in the example), and a very short message corresponding to the status code (OK in the example).

Following is a summary of the most useful HTTP 1.1 response headers which go back to the browser from the web server. These headers are frequently used in web programming −

S.No. Header & Description
1

Allow

This header specifies the request methods (GET, POST, etc.) that the server supports.

2

Cache-Control

This header specifies the circumstances in which the response document can safely be cached. It can have values public, private or no-cache etc. Public means document is cacheable, Private means document is for a single user and can only be stored in private (nonshared) caches and no-cache means document should never be cached.

3

Connection

This header instructs the browser whether to use persistent HTTP connections or not. A value of close instructs the browser not to use persistent HTTP connections and keep-alive means using persistent connections.

4

Content-Disposition

This header lets you request that the browser ask the user to save the response to disk in a file of the given name.

5

Content-Encoding

This header specifies the way in which the page was encoded during transmission.

6

Content-Language

This header signifies the language in which the document is written. For example, en, en-us, ru, etc.

7

Content-Length

This header indicates the number of bytes in the response. This information is needed only if the browser is using a persistent (keep-alive) HTTP connection.

8

Content-Type

This header gives the MIME (Multipurpose Internet Mail Extension) type of the response document.

9

Expires

This header specifies the time at which the content should be considered out-of-date and thus no longer be cached.

10

Last-Modified

This header indicates when the document was last changed. The client can then cache the document and supply a date by an If-Modified-Since request header in later requests.

11

Location

This header should be included with all responses that have a status code in the 300s. This notifies the browser of the document address. The browser automatically reconnects to this location and retrieves the new document.

12

Refresh

This header specifies how soon the browser should ask for an updated page. You can specify time in number of seconds after which a page would be refreshed.

13

Retry-After

This header can be used in conjunction with a 503 (Service Unavailable) response to tell the client how soon it can repeat its request.

14

Set-Cookie

This header specifies a cookie associated with the page.

The HttpServletResponse Object

The response object is an instance of a javax.servlet.http.HttpServletResponse object. Just as the server creates the request object, it also creates an object to represent the response to the client.

The response object also defines the interfaces that deal with creating new HTTP headers. Through this object, the JSP programmer can add new cookies or date stamps, HTTP status codes etc.

The following methods can be used to set HTTP response header in your servlet program. These methods are available with the HttpServletResponse object. This object represents the server response.

S.No. Method & Description
1

String encodeRedirectURL(String url)

Encodes the specified URL for use in the sendRedirect method or, if encoding is not needed, returns the URL unchanged.

2

String encodeURL(String url)

Encodes the specified URL by including the session ID in it, or, if encoding is not needed, returns the URL unchanged.

3

boolean containsHeader(String name)

Returns a boolean indicating whether the named response header has already been set.

4

boolean isCommitted()

Returns a boolean indicating if the response has been committed.

5

void addCookie(Cookie cookie)

Adds the specified cookie to the response.

6

void addDateHeader(String name, long date)

Adds a response header with the given name and date-value.

7

void addHeader(String name, String value)

Adds a response header with the given name and value.

8

void addIntHeader(String name, int value)

Adds a response header with the given name and integer value.

9

void flushBuffer()

Forces any content in the buffer to be written to the client.

10

void reset()

Clears any data that exists in the buffer as well as the status code and headers.

11

void resetBuffer()

Clears the content of the underlying buffer in the response without clearing headers or status code.

12

void sendError(int sc)

Sends an error response to the client using the specified status code and clearing the buffer.

13

void sendError(int sc, String msg)

Sends an error response to the client using the specified status.

14

void sendRedirect(String location)

Sends a temporary redirect response to the client using the specified redirect location URL.

15

void setBufferSize(int size)

Sets the preferred buffer size for the body of the response.

16

void setCharacterEncoding(String charset)

Sets the character encoding (MIME charset) of the response being sent to the client, for example, to UTF-8.

17

void setContentLength(int len)

Sets the length of the content body in the response In HTTP servlets; this method also sets the HTTP Content-Length header.

18

void setContentType(String type)

Sets the content type of the response being sent to the client, if the response has not been committed yet.

19

void setDateHeader(String name, long date)

Sets a response header with the given name and date-value.

20

void setHeader(String name, String value)

Sets a response header with the given name and value.

21

void setIntHeader(String name, int value)

Sets a response header with the given name and integer value.

22

void setLocale(Locale loc)

Sets the locale of the response, if the response has not been committed yet.

23

void setStatus(int sc)

Sets the status code for this response.

HTTP Header Response Example

Following example would use setIntHeader() method to set Refresh header to simulate a digital clock −

<%@ page import = "java.io.*,java.util.*" %>

<html>
   
   <head>
      <title>Auto Refresh Header Example</title>
   </head>
   
   <body>
      <center>
         <h2>Auto Refresh Header Example</h2>
         <%
            // Set refresh, autoload time as 5 seconds
            response.setIntHeader("Refresh", 5);
            
            // Get current time
            Calendar calendar = new GregorianCalendar();
            
            String am_pm;
            int hour = calendar.get(Calendar.HOUR);
            int minute = calendar.get(Calendar.MINUTE);
            int second = calendar.get(Calendar.SECOND);
            
            if(calendar.get(Calendar.AM_PM) == 0) 
               am_pm = "AM";
            else
               am_pm = "PM";
               String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
               out.println("Current Time is: " + CT + "\n");
         %>
      </center>
   
   </body>
</html>

Now put the above code in main.jsp and try to access it. This will display the current system time after every 5 seconds as follows. Run the JSP. You will receive the following output: −

Auto Refresh Header Example

Current Time is: 9:44:50 PM

You can try working out on the other methods in a similar way.

In this chapter, we will discuss the Http Status Codes in JSP. The format of the HTTP request and the HTTP response messages are similar and will have the following structure −

  • An initial status line + CRLF (Carriage Return + Line Feed ie. New Line)

  • Zero or more header lines + CRLF

  • A blank line ie. a CRLF

  • An optional message body like file, query data or query output.

For example, a server response header looks like the following −

HTTP/1.1 200 OK
Content-Type: text/html
Header2: ...
...
HeaderN: ...
   (Blank Line)
<!doctype ...>

<html>
   <head>...</head>
   
   <body>
      ...
   </body>
</html>

The status line consists of the HTTP version (HTTP/1.1 in the example), a status code (200 in the example), and a very short message corresponding to the status code (OK in the example).

Following table lists out the HTTP status codes and associated messages that might be returned from the Web Server −

Code Message Description
100 Continue Only a part of the request has been received by the server, but as long as it has not been rejected, the client should continue with the request
101 Switching Protocols The server switches protocol.
200 OK The request is OK
201 Created The request is complete, and a new resource is created 
202 Accepted The request is accepted for processing, but the processing is not complete.
203 Non-authoritative Information
204 No Content
205 Reset Content
206 Partial Content
300 Multiple Choices A link list; the user can select a link and go to that location. Maximum five addresses.
301 Moved Permanently The requested page has moved to a new url.
302 Found The requested page has moved temporarily to a new url.
303 See Other The requested page can be found under a different url.
304 Not Modified
305 Use Proxy
306 Unused This code was used in a previous version. It is no longer used, but the code is reserved.
307 Temporary Redirect The requested page has moved temporarily to a new url.
400 Bad Request The server did not understand the request.
401 Unauthorized The requested page needs a username and a password.
402 Payment Required You can not use this code yet.
403 Forbidden Access is forbidden to the requested page
404 Not Found The server can not find the requested page.
405 Method Not Allowed The method specified in the request is not allowed.
406 Not Acceptable The server can only generate a response that is not accepted by the client.
407 Proxy Authentication Required You must authenticate with a proxy server before this request can be served.
408 Request Timeout The request took longer than the server was prepared to wait.
409 Conflict The request could not be completed because of a conflict.
410 Gone The requested page is no longer available.
411 Length Required The "Content-Length" is not defined. The server will not accept the request without it.
412 Precondition Failed The precondition given in the request evaluated to false by the server.
413 Request Entity Too Large The server will not accept the request, because the request entity is too large.
414 Request-url Too Long The server will not accept the request, because the url is too long. This occurs when you convert a "post" request to a "get" request with a long query information.
415 Unsupported Media Type The server will not accept the request, because the media type is not supported.
417 Expectation Failed
500 Internal Server Error The request was not completed. The server met an unexpected condition.
501 Not Implemented The request was not completed. The server did not support the functionality required.
502 Bad Gateway The request was not completed. The server received an invalid response from the upstream server.
503 Service Unavailable The request was not completed. The server is temporarily overloading or down.
504 Gateway Timeout The gateway has timed out.
505 HTTP Version Not Supported The server does not support the "http protocol" version.

Methods to Set HTTP Status Code

Following methods can be used to set the HTTP Status Code in your servlet program. These methods are available with the HttpServletResponse object.

S.No. Method & Description
1

public void setStatus ( int statusCode )

This method sets an arbitrary status code. The setStatus method takes an int (the status code) as an argument. If your response includes a special status code and a document, be sure to call setStatus before actually returning any of the content with the PrintWriter.

2

public void sendRedirect(String url)

This method generates a 302 response along with a Location header giving the URL of the new document.

3

public void sendError(int code, String message)

This method sends a status code (usually 404) along with a short message that is automatically formatted inside an HTML document and sent to the client.

HTTP Status Code Example

Following example shows how a 407 error code is sent to the client browser. After this, the browser would show you "Need authentication!!!" message.

<html>
   <head>
      <title>Setting HTTP Status Code</title>
   </head>
   
   <body>
      <%
         // Set error code and reason.
         response.sendError(407, "Need authentication!!!" );
      %>
   </body>
</html>

You will receive the following output −

HTTP Status 407 - Need authentication!!!

type Status report

message Need authentication!!!

description The client must first authenticate itself with the proxy (Need authentication!!!).

Apache Tomcat/5.5.29

To become more comfortable with HTTP status codes, try to set different status codes and their description.

In this chapter, we will discuss Form Processing in JSP. You must have come across many situations when you need to pass some information from your browser to the web server and ultimately to your backend program. The browser uses two methods to pass this information to the web server. These methods are the GET Method and the POST Method.

The Methods in Form Processing

Let us now discuss the methods in Form Processing.

GET method

The GET method sends the encoded user information appended to the page request. The page and the encoded information are separated by the ? character as follows −

http://www.test.com/hello?key1=value1&key2=value2

The GET method is the default method to pass information from the browser to the web server and it produces a long string that appears in your browser's Location:box. It is recommended that the GET method is better not used. if you have password or other sensitive information to pass to the server.

The GET method has size limitation: only 1024 characters can be in a request string.

This information is passed using QUERY_STRING header and will be accessible through QUERY_STRING environment variable which can be handled using getQueryString() and getParameter() methods of request object.

POST method

A generally more reliable method of passing information to a backend program is the POST method.

This method packages the information in exactly the same way as the GET method, but instead of sending it as a text string after a ? in the URL it sends it as a separate message. This message comes to the backend program in the form of the standard input which you can parse and use for your processing.

JSP handles this type of requests using getParameter() method to read simple parameters and getInputStream() method to read binary data stream coming from the client.

Reading Form Data using JSP

JSP handles form data parsing automatically using the following methods depending on the situation −

  • getParameter() − You call request.getParameter() method to get the value of a form parameter.

  • getParameterValues() − Call this method if the parameter appears more than once and returns multiple values, for example checkbox.

  • getParameterNames() − Call this method if you want a complete list of all parameters in the current request.

  • getInputStream() − Call this method to read binary data stream coming from the client.

GET Method Example Using URL

The following URL will pass two values to HelloForm program using the GET method.

http://localhost:8080/main.jsp?first_name=ZARA&last_name=ALI

Below is the main.jsp JSP program to handle input given by web browser. We are going to use the getParameter() method which makes it very easy to access the passed information −

<html>
   <head>
      <title>Using GET Method to Read Form Data</title>
   </head>
   
   <body>
      <h1>Using GET Method to Read Form Data</h1>
      <ul>
         <li><p><b>First Name:</b>
            <%= request.getParameter("first_name")%>
         </p></li>
         <li><p><b>Last  Name:</b>
            <%= request.getParameter("last_name")%>
         </p></li>
      </ul>
   
   </body>
</html>

Now type http://localhost:8080/main.jsp?first_name=ZARA&last_name=ALI in your browser's Location:box. This will generate the following result −

Using GET Method to Read Form Data

  • First Name: ZARA

  • Last Name: ALI

GET Method Example Using Form

Following is an example that passes two values using the HTML FORM and the submit button. We are going to use the same JSP main.jsp to handle this input.

<html>
   <body>
      
      <form action = "main.jsp" method = "GET">
         First Name: <input type = "text" name = "first_name">
         <br />
         Last Name: <input type = "text" name = "last_name" />
         <input type = "submit" value = "Submit" />
      </form>
      
   </body>
</html>

Keep this HTML in a file Hello.htm and put it in <Tomcat-installation-directory>/webapps/ROOT directory. When you would access http://localhost:8080/Hello.htm, you will receive the following output.

POST Method Example Using Form

Let us do a little modification in the above JSP to handle both the GET and the POST method. Below is the main.jsp JSP program to handle the input given by web browser using the GET or the POST methods.

Infact there is no change in the above JSP because the only way of passing parameters is changed and no binary data is being passed to the JSP program. File handling related concepts will be explained in separate chapter where we need to read the binary data stream.

<html>
   <head>
      <title>Using GET and POST Method to Read Form Data</title>
   </head>
   
   <body>
      <center>
      <h1>Using POST Method to Read Form Data</h1>
      
      <ul>
         <li><p><b>First Name:</b>
            <%= request.getParameter("first_name")%>
         </p></li>
         <li><p><b>Last  Name:</b>
            <%= request.getParameter("last_name")%>
         </p></li>
      </ul>
   
   </body>
</html>

Following is the content of the Hello.htm file −

<html>
   <body>
      
      <form action = "main.jsp" method = "POST">
         First Name: <input type = "text" name = "first_name">
         <br />
         Last Name: <input type = "text" name = "last_name" />
         <input type = "submit" value = "Submit" />
      </form>
      
   </body>
</html>

Let us now keep main.jsp and hello.htm in <Tomcat-installationdirectory>/webapps/ROOT directory. When you access http://localhost:8080/Hello.htm, you will receive the following output.

Try to enter the First and the Last Name and then click the submit button to see the result on your local machine where tomcat is running.

Based on the input provided, you will receive similar results as in the above examples.

Passing Checkbox Data to JSP Program

Checkboxes are used when more than one option is required to be selected.

Following is an example HTML code, CheckBox.htm, for a form with two checkboxes.

<html>
   <body>
      
      <form action = "main.jsp" method = "POST" target = "_blank">
         <input type = "checkbox" name = "maths" checked = "checked" /> Maths
         <input type = "checkbox" name = "physics"  /> Physics
         <input type = "checkbox" name = "chemistry" checked = "checked" /> Chemistry
         <input type = "submit" value = "Select Subject" />
      </form>
      
   </body>
</html>

The above code will generate the following result −

Following is main.jsp JSP program to handle the input given by the web browser for the checkbox button.

<html>
   <head>
      <title>Reading Checkbox Data</title>
   </head>
   
   <body>
      <h1>Reading Checkbox Data</h1>
      
      <ul>
         <li><p><b>Maths Flag:</b>
            <%= request.getParameter("maths")%>
         </p></li>
         <li><p><b>Physics Flag:</b>
            <%= request.getParameter("physics")%>
         </p></li>
         <li><p><b>Chemistry Flag:</b>
            <%= request.getParameter("chemistry")%>
         </p></li>
      </ul>
   
   </body>
</html>

The above program will generate the following result −

Reading Checkbox Data

  • Maths Flag :: on

  • Physics Flag:: null

  • Chemistry Flag:: on

Reading All Form Parameters

Following is a generic example which uses getParameterNames() method of HttpServletRequest to read all the available form parameters. This method returns an Enumeration that contains the parameter names in an unspecified order.

Once we have an Enumeration, we can loop down the Enumeration in the standard manner, using the hasMoreElements() method to determine when to stop and using the nextElement() method to get each parameter name.

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>HTTP Header Request Example</title>
   </head>

   <body>
      <center>
         <h2>HTTP Header Request Example</h2>
         <table width = "100%" border = "1" align = "center">
            <tr bgcolor = "#949494">
               <th>Param Name</th>
               <th>Param Value(s)</th>
            </tr>
            <%
               Enumeration paramNames = request.getParameterNames();
               while(paramNames.hasMoreElements()) {
                  String paramName = (String)paramNames.nextElement();
                  out.print("<tr><td>" + paramName + "</td>\n");
                  String paramValue = request.getHeader(paramName);
                  out.println("<td> " + paramValue + "</td></tr>\n");
               }
            %>
         </table>
      </center>
   
   </body>
</html>

Voici le contenu de la Hello.htm -

<html>
   <body>
      
      <form action = "main.jsp" method = "POST" target = "_blank">
         <input type = "checkbox" name = "maths" checked = "checked" /> Maths
         <input type = "checkbox" name = "physics"  /> Physics
         <input type = "checkbox" name = "chemistry" checked = "checked" /> Chem
         <input type = "submit" value = "Select Subject" />
      </form>
   
   </body>
</html>

Essayez maintenant d'appeler JSP en utilisant le Hello.htm ci-dessus; cela générerait un résultat comme ci-dessous en fonction de l'entrée fournie -

Lecture de tous les paramètres du formulaire

Nom du paramètre Valeur (s) de paramètre
mathématiques sur
chimie sur

Vous pouvez essayer le JSP ci-dessus pour lire les données de tout autre formulaire contenant d'autres objets comme une zone de texte, un bouton radio ou une liste déroulante, etc.

Dans ce chapitre, nous aborderons les filtres dans JSP. Les filtres Servlet et JSP sont des classes Java qui peuvent être utilisées dans la programmation Servlet et JSP aux fins suivantes:

  • Pour intercepter les demandes d'un client avant qu'il n'accède à une ressource en back-end.

  • Pour manipuler les réponses du serveur avant qu'elles ne soient renvoyées au client.

Il existe différents types de filtres suggérés par les spécifications -

  • Filtres d'authentification
  • Filtres de compression de données
  • Filtres de cryptage
  • Filtres qui déclenchent des événements d'accès aux ressources
  • Filtres de conversion d'image
  • Filtres de journalisation et d'audit
  • Filtres de chaîne MIME-TYPE
  • Filtres de tokenisation
  • Filtres XSL / T qui transforment le contenu XML

Les filtres sont déployés dans le fichier descripteur de déploiement web.xmlpuis mappez vers les noms de servlet ou JSP ou les modèles d'URL dans le descripteur de déploiement de votre application. Le fichier descripteur de déploiement web.xml se trouve dans le répertoire <Tomcat-installation-directory> \ conf .

Lorsque le conteneur JSP démarre votre application Web, il crée une instance de chaque filtre que vous avez déclaré dans le descripteur de déploiement. Les filtres s'exécutent dans l'ordre dans lequel ils sont déclarés dans le descripteur de déploiement.

Méthodes de filtrage des servlets

Un filtre est simplement une classe Java qui implémente le javax.servlet.Filterinterface. L'interface javax.servlet.Filter définit trois méthodes -

S.No. Méthode et description
1

public void doFilter (ServletRequest, ServletResponse, FilterChain)

Cette méthode est appelée par le conteneur à chaque fois qu'une paire demande / réponse est passée dans la chaîne en raison d'une demande client pour une ressource à la fin de la chaîne.

2

public void init(FilterConfig filterConfig)

Cette méthode est appelée par le conteneur Web pour indiquer à un filtre qu'il est mis en service.

3

public void destroy()

Cette méthode est appelée par le conteneur Web pour indiquer à un filtre qu'il est mis hors service.

Exemple de filtre JSP

L'exemple suivant montre comment imprimer l'adresse IP du client et la date actuelle, chaque fois qu'il accède à un fichier JSP. Cet exemple vous donnera une compréhension de base du filtre JSP, mais vous pouvez écrire des applications de filtre plus sophistiquées en utilisant le même concept -

// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
 
// Implements Filter class
public class LogFilter implements Filter  {
   public void  init(FilterConfig config) throws ServletException {
      // Get init parameter 
      String testParam = config.getInitParameter("test-param"); 
 
      //Print the init parameter 
      System.out.println("Test Param: " + testParam); 
   }
   public void  doFilter(ServletRequest request, ServletResponse response, FilterChain chain) 
      throws java.io.IOException, ServletException {
      
      // Get the IP address of client machine.   
      String ipAddress = request.getRemoteAddr();
      
      // Log the IP address and current timestamp.
      System.out.println("IP "+ ipAddress + ", Time "+ new Date().toString());
      
      // Pass request back down the filter chain
      chain.doFilter(request,response);
   }
   public void destroy( ) {
      /* Called before the Filter instance is removed 
      from service by the web container*/
   }
}

Compiler LogFilter.java de la manière habituelle et mettez votre LogFilter.class déposer dans <Tomcat-installation-directory>/webapps/ROOT/WEB-INF/classes.

Mappage de filtres JSP dans Web.xml

Les filtres sont définis, puis mappés à un nom de fichier URL ou JSP, de la même manière que le servlet est défini, puis mappé à un modèle d'URL dans web.xmlfichier. Créez l'entrée suivante pour la balise de filtre dans le fichier descripteur de déploiementweb.xml

<filter>
   <filter-name>LogFilter</filter-name>
   <filter-class>LogFilter</filter-class>
   
   <init-param>
      <param-name>test-param</param-name>
      <param-value>Initialization Paramter</param-value>
   </init-param>
</filter>

<filter-mapping>
   <filter-name>LogFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>

Le filtre ci-dessus s'appliquera à toutes les servlets et JSP car nous avons spécifié /*dans notre configuration. Vous pouvez spécifier un servlet particulier ou le chemin JSP si vous souhaitez appliquer le filtre à quelques servlets ou à JSP uniquement.

Essayez maintenant d'appeler n'importe quel servlet ou JSP et vous verrez le journal généré dans le journal de votre serveur Web. Vous pouvez utiliserLog4J logger pour vous connecter ci-dessus, connectez-vous dans un fichier séparé.

Utilisation de plusieurs filtres

Votre application Web peut définir plusieurs filtres différents dans un but précis. Considérez, vous définissez deux filtres AuthenFilter et LogFilter . Le reste du processus restera comme expliqué ci-dessus, sauf que vous devez créer un mappage différent comme mentionné ci-dessous -

<filter>
   <filter-name>LogFilter</filter-name>
   <filter-class>LogFilter</filter-class>
   
   <init-param>
      <param-name>test-param</param-name>
      <param-value>Initialization Paramter</param-value>
   </init-param>
</filter>
 
<filter>
   <filter-name>AuthenFilter</filter-name>
   <filter-class>AuthenFilter</filter-class>
   <init-param>
      <param-name>test-param</param-name>
      <param-value>Initialization Paramter</param-value>
   </init-param>
</filter>
 
<filter-mapping>
   <filter-name>LogFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>
 
<filter-mapping>
   <filter-name>AuthenFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>

Ordre des applications des filtres

L'ordre des éléments de mappage de filtre dans web.xml détermine l'ordre dans lequel le conteneur Web applique le filtre au servlet ou à la JSP. Pour inverser l'ordre du filtre, il vous suffit d'inverser les éléments de mappage de filtre dans leweb.xml fichier.

Par exemple, l'exemple ci-dessus appliquera d'abord le LogFilter, puis il appliquera AuthenFilter à n'importe quel servlet ou JSP; l'exemple suivant inversera l'ordre -

<filter-mapping>
   <filter-name>AuthenFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>
 
<filter-mapping>
   <filter-name>LogFilter</filter-name>
   <url-pattern>/*</url-pattern>
</filter-mapping>

Dans ce chapitre, nous aborderons la gestion des cookies dans JSP. Les cookies sont des fichiers texte stockés sur l'ordinateur client et ils sont conservés à diverses fins de suivi des informations. JSP prend en charge de manière transparente les cookies HTTP en utilisant la technologie de servlet sous-jacente.

L'identification et le retour des utilisateurs comportent trois étapes:

  • Le script serveur envoie un ensemble de cookies au navigateur. Par exemple, nom, âge ou numéro d'identification, etc.

  • Le navigateur stocke ces informations sur la machine locale pour une utilisation future.

  • Lorsque la prochaine fois que le navigateur envoie une demande au serveur Web, il envoie ces informations sur les cookies au serveur et le serveur utilise ces informations pour identifier l'utilisateur ou peut également l'être à d'autres fins.

Ce chapitre vous apprendra comment définir ou réinitialiser les cookies, comment y accéder et comment les supprimer à l'aide des programmes JSP.

L'anatomie d'un cookie

Les cookies sont généralement définis dans un en-tête HTTP (bien que JavaScript puisse également définir un cookie directement sur un navigateur). Une JSP qui définit un cookie peut envoyer des en-têtes qui ressemblent à ceci -

HTTP/1.1 200 OK
Date: Fri, 04 Feb 2000 21:03:38 GMT
Server: Apache/1.3.9 (UNIX) PHP/4.0b3
Set-Cookie: name = xyz; expires = Friday, 04-Feb-07 22:03:38 GMT; 
   path = /; domain = tutorialspoint.com
Connection: close
Content-Type: text/html

Comme vous pouvez le voir, le Set-Cookie header contient a name value pair, a GMT date, a path et a domain. Le nom et la valeur seront encodés en URL. leexpires champ est une instruction au navigateur pour "forget" le cookie après l'heure et la date données.

Si le navigateur est configuré pour stocker des cookies, il conservera alors ces informations jusqu'à la date d'expiration. Si l'utilisateur pointe le navigateur vers une page qui correspond au chemin et au domaine du cookie, il renverra le cookie au serveur. Les en-têtes du navigateur peuvent ressembler à ceci -

GET / HTTP/1.0
Connection: Keep-Alive
User-Agent: Mozilla/4.6 (X11; I; Linux 2.2.6-15apmac ppc)
Host: zink.demon.co.uk:1126

Accept: image/gif, */*
Accept-Encoding: gzip
Accept-Language: en
Accept-Charset: iso-8859-1,*,utf-8
Cookie: name = xyz

Un script JSP aura alors accès aux cookies via la méthode de requête request.getCookies()qui renvoie un tableau d' objets Cookie .

Méthodes de cookies de servlet

Le tableau suivant répertorie les méthodes utiles associées à l'objet Cookie que vous pouvez utiliser lors de la manipulation des cookies dans JSP -

S.No. Méthode et description
1

public void setDomain(String pattern)

Cette méthode définit le domaine auquel le cookie s'applique; par exemple, tutorialspoint.com.

2

public String getDomain()

Cette méthode obtient le domaine auquel s'applique le cookie; par exemple, tutorialspoint.com.

3

public void setMaxAge(int expiry)

Cette méthode définit la durée (en secondes) qui doit s'écouler avant l'expiration du cookie. Si vous ne définissez pas cela, le cookie ne durera que pour la session en cours.

4

public int getMaxAge()

Cette méthode renvoie l'âge maximum du cookie, spécifié en secondes, Par défaut, -1 indiquant que le cookie persistera jusqu'à l'arrêt du navigateur.

5

public String getName()

Cette méthode renvoie le nom du cookie. Le nom ne peut pas être modifié après la création.

6

public void setValue(String newValue)

Cette méthode définit la valeur associée au cookie.

sept

public String getValue()

Cette méthode obtient la valeur associée au cookie.

8

public void setPath(String uri)

Cette méthode définit le chemin auquel ce cookie s'applique. Si vous ne spécifiez pas de chemin, le cookie est renvoyé pour toutes les URL dans le même répertoire que la page actuelle ainsi que pour tous les sous-répertoires.

9

public String getPath()

Cette méthode obtient le chemin auquel ce cookie s'applique.

dix

public void setSecure(boolean flag)

Cette méthode définit la valeur booléenne indiquant si le cookie doit être envoyé uniquement via des connexions cryptées (c'est-à-dire SSL).

11

public void setComment(String purpose)

Cette méthode spécifie un commentaire qui décrit le but d'un cookie. Le commentaire est utile si le navigateur présente le cookie à l'utilisateur.

12

public String getComment()

Cette méthode retourne le commentaire décrivant le but de ce cookie, ou null si le cookie n'a pas de commentaire.

Définition de cookies avec JSP

La configuration des cookies avec JSP implique trois étapes -

Étape 1: création d'un objet Cookie

Vous appelez le constructeur Cookie avec un nom de cookie et une valeur de cookie, qui sont tous deux des chaînes.

Cookie cookie = new Cookie("key","value");

Gardez à l'esprit que ni le nom ni la valeur ne doivent contenir d'espace blanc ou l'un des caractères suivants -

[ ] ( ) = , " / ? @ : ;

Étape 2: Définition de l'âge maximum

Tu utilises setMaxAgepour spécifier la durée (en secondes) du cookie doit être valide. Le code suivant installera un cookie pendant 24 heures.

cookie.setMaxAge(60*60*24);

Étape 3: Envoi du cookie dans les en-têtes de réponse HTTP

Tu utilises response.addCookie pour ajouter des cookies dans l'en-tête de la réponse HTTP comme suit

response.addCookie(cookie);

Exemple

Modifions notre exemple de formulaire pour définir les cookies pour le prénom et le nom.

<%
   // Create cookies for first and last names.      
   Cookie firstName = new Cookie("first_name", request.getParameter("first_name"));
   Cookie lastName = new Cookie("last_name", request.getParameter("last_name"));
   
   // Set expiry date after 24 Hrs for both the cookies.
   firstName.setMaxAge(60*60*24); 
   lastName.setMaxAge(60*60*24); 
   
   // Add both the cookies in the response header.
   response.addCookie( firstName );
   response.addCookie( lastName );
%>

<html>
   <head>
      <title>Setting Cookies</title>
   </head>
   
   <body>
      <center>
         <h1>Setting Cookies</h1>
      </center>
      <ul>
         <li><p><b>First Name:</b>
            <%= request.getParameter("first_name")%>
         </p></li>
         <li><p><b>Last  Name:</b>
            <%= request.getParameter("last_name")%>
         </p></li>
      </ul>
   
   </body>
</html>

Mettons le code ci-dessus dans main.jsp fichier et utilisez-le dans la page HTML suivante -

<html>
   <body>
      
      <form action = "main.jsp" method = "GET">
         First Name: <input type = "text" name = "first_name">
         <br />
         Last Name: <input type = "text" name = "last_name" />
         <input type = "submit" value = "Submit" />
      </form>
      
   </body>
</html>

Conservez le contenu HTML ci-dessus dans un fichier hello.jsp et met hello.jsp et main.jsp dans <Tomcat-installation-directory>/webapps/ROOTannuaire. Quand vous accéderezhttp://localhost:8080/hello.jsp, voici la sortie réelle du formulaire ci-dessus.

Essayez d'entrer le prénom et le nom de famille, puis cliquez sur le bouton Soumettre. Cela affichera le prénom et le nom sur votre écran et définira également deux cookiesfirstName et lastName. Ces cookies seront renvoyés au serveur la prochaine fois que vous cliquerez sur le bouton Soumettre.

Dans la section suivante, nous expliquerons comment vous pouvez accéder à ces cookies dans votre application Web.

Lire les cookies avec JSP

Pour lire les cookies, vous devez créer un tableau d' objets javax.servlet.http.Cookie en appelant legetCookies( )méthode de HttpServletRequest . Ensuite, parcourez le tableau et utilisezgetName() et getValue() méthodes pour accéder à chaque cookie et valeur associée.

Exemple

Lisons maintenant les cookies qui ont été définis dans l'exemple précédent -

<html>
   <head>
      <title>Reading Cookies</title>
   </head>
   
   <body>
      <center>
         <h1>Reading Cookies</h1>
      </center>
      <%
         Cookie cookie = null;
         Cookie[] cookies = null;
         
         // Get an array of Cookies associated with the this domain
         cookies = request.getCookies();
         
         if( cookies != null ) {
            out.println("<h2> Found Cookies Name and Value</h2>");
            
            for (int i = 0; i < cookies.length; i++) {
               cookie = cookies[i];
               out.print("Name : " + cookie.getName( ) + ",  ");
               out.print("Value: " + cookie.getValue( )+" <br/>");
            }
         } else {
            out.println("<h2>No cookies founds</h2>");
         }
      %>
   </body>
   
</html>

Mettons maintenant le code ci-dessus dans main.jspfichier et essayez d'y accéder. Si vous définissez lefirst_name cookie comme "John" et le last_name cookie comme "Player" puis en cours d'exécution http://localhost:8080/main.jsp affichera le résultat suivant -

Found Cookies Name and Value

Name : first_name, Value: John

Name : last_name, Value: Player

Supprimer les cookies avec JSP

Supprimer les cookies est très simple. Si vous souhaitez supprimer un cookie, il vous suffit de suivre ces trois étapes -

  • Lisez un cookie déjà existant et stockez-le dans l'objet Cookie.

  • Définissez l'âge des cookies sur zéro à l'aide du setMaxAge() méthode pour supprimer un cookie existant.

  • Ajoutez ce cookie dans l'en-tête de la réponse.

Exemple

L'exemple suivant vous montrera comment supprimer un cookie existant nommé "first_name" et lorsque vous exécuterez la JSP main.jsp la prochaine fois, il renverra une valeur nulle pour first_name.

<html>
   <head>
      <title>Reading Cookies</title>
   </head>
   
   <body>
      <center>
         <h1>Reading Cookies</h1>
      </center>
      <%
         Cookie cookie = null;
         Cookie[] cookies = null;
         
         // Get an array of Cookies associated with the this domain
         cookies = request.getCookies();
         
         if( cookies != null ) {
            out.println("<h2> Found Cookies Name and Value</h2>");
            
            for (int i = 0; i < cookies.length; i++) {
               cookie = cookies[i];
               
               if((cookie.getName( )).compareTo("first_name") == 0 ) {
                  cookie.setMaxAge(0);
                  response.addCookie(cookie);
                  out.print("Deleted cookie: " + 
                  cookie.getName( ) + "<br/>");
               }
               out.print("Name : " + cookie.getName( ) + ",  ");
               out.print("Value: " + cookie.getValue( )+" <br/>");
            }
         } else {
            out.println(
            "<h2>No cookies founds</h2>");
         }
      %>
   </body>
   
</html>

Mettons maintenant le code ci-dessus dans le main.jspfichier et essayez d'y accéder. Il affichera le résultat suivant -

Cookies Name and Value

Deleted cookie : first_name

Name : first_name, Value: John

Name : last_name, Value: Player

Maintenant, exécutez à nouveau http: // localhost: 8080 / main.jsp et il ne devrait afficher qu'un seul cookie comme suit -

Found Cookies Name and Value

Name : last_name, Value: Player

Vous pouvez supprimer manuellement vos cookies dans Internet Explorer. Démarrez dans le menu Outils et sélectionnez les Options Internet. Pour supprimer tous les cookies, cliquez sur le bouton Supprimer les cookies.

Dans ce chapitre, nous aborderons le suivi de session dans JSP. HTTP est un protocole «sans état», ce qui signifie que chaque fois qu'un client récupère une page Web, le client ouvre une connexion distincte au serveur Web et le serveur ne conserve automatiquement aucun enregistrement de la demande client précédente.

Maintien de la session entre le client Web et le serveur

Voyons maintenant quelques options pour maintenir la session entre le client Web et le serveur Web -

Biscuits

Un serveur Web peut attribuer un identifiant de session unique en tant que cookie à chaque client Web et pour les demandes ultérieures du client, il peut être reconnu à l'aide du cookie reçu.

Cela peut ne pas être un moyen efficace car le navigateur ne prend parfois pas en charge un cookie. Il n'est pas recommandé d'utiliser cette procédure pour maintenir les sessions.

Champs de formulaire masqués

Un serveur Web peut envoyer un champ de formulaire HTML masqué avec un ID de session unique comme suit -

<input type = "hidden" name = "sessionid" value = "12345">

Cette entrée signifie que, lorsque le formulaire est soumis, le nom et la valeur spécifiés sont automatiquement inclus dans le GET ou la POSTLes données. Chaque fois que le navigateur Web renvoie la demande, lesession_id value peut être utilisé pour garder la trace de différents navigateurs Web.

Cela peut être un moyen efficace de garder une trace de la session, mais cliquer sur un lien hypertexte régulier (<A HREF...>) n'entraîne pas l'envoi d'un formulaire, de sorte que les champs de formulaire masqués ne peuvent pas non plus prendre en charge le suivi général de session.

Réécriture d'URL

Vous pouvez ajouter des données supplémentaires à la fin de chaque URL. Ces données identifient la session; le serveur peut associer cet identifiant de session aux données qu'il a stockées sur cette session.

Par exemple, avec http://tutorialspoint.com/file.htm;sessionid=12345, l'identifiant de session est joint en tant que sessionid = 12345 accessible sur le serveur Web pour identifier le client.

La réécriture d'URL est un meilleur moyen de maintenir les sessions et fonctionne pour les navigateurs lorsqu'ils ne prennent pas en charge les cookies. L'inconvénient ici est que vous devrez générer chaque URL dynamiquement pour attribuer un ID de session bien que la page soit une simple page HTML statique.

L'objet de session

Outre les options mentionnées ci-dessus, JSP utilise l'interface HttpSession fournie par le servlet. Cette interface permet d'identifier un utilisateur à travers.

  • une demande d'une page ou
  • visite d'un site Web ou
  • stocker des informations sur cet utilisateur

Par défaut, le suivi de session est activé sur les JSP et un nouvel objet HttpSession est automatiquement instancié pour chaque nouveau client. La désactivation du suivi de session nécessite de le désactiver explicitement en définissant l'attribut de session de directive de page sur false comme suit -

<%@ page session = "false" %>

Le moteur JSP expose l'objet HttpSession à l'auteur JSP via le sessionobjet. Depuissession objet est déjà fourni au programmeur JSP, le programmeur peut immédiatement commencer à stocker et à récupérer les données de l'objet sans aucune initialisation ou getSession().

Voici un résumé des méthodes importantes disponibles via l'objet session -

S.No. Méthode et description
1

public Object getAttribute(String name)

Cette méthode renvoie l'objet lié avec le nom spécifié dans cette session, ou null si aucun objet n'est lié sous le nom.

2

public Enumeration getAttributeNames()

Cette méthode retourne une énumération d'objets String contenant les noms de tous les objets liés à cette session.

3

public long getCreationTime()

Cette méthode renvoie l'heure à laquelle cette session a été créée, mesurée en millisecondes depuis le 1er janvier 1970 à minuit (GMT).

4

public String getId()

Cette méthode renvoie une chaîne contenant l'identifiant unique attribué à cette session.

5

public long getLastAccessedTime()

Cette méthode renvoie la dernière fois que le client a envoyé une requête associée à cette session, sous la forme du nombre de millisecondes depuis le 1er janvier 1970 à minuit, heure GMT.

6

public int getMaxInactiveInterval()

Cette méthode renvoie l'intervalle de temps maximal, en secondes, pendant lequel le conteneur de servlet maintiendra cette session ouverte entre les accès client.

sept

public void invalidate()

Cette méthode invalide cette session et dissocie tous les objets qui y sont liés.

8

public boolean isNew()

Cette méthode retourne true si le client ne connaît pas encore la session ou si le client choisit de ne pas rejoindre la session.

9

public void removeAttribute(String name)

Cette méthode supprime l'objet lié avec le nom spécifié de cette session.

dix

public void setAttribute(String name, Object value)

Cette méthode lie un objet à cette session, en utilisant le nom spécifié.

11

public void setMaxInactiveInterval(int interval)

Cette méthode spécifie le temps, en secondes, entre les demandes du client avant que le conteneur de servlet n'invalide cette session.

Exemple de suivi de session

Cet exemple décrit comment utiliser l'objet HttpSession pour connaître l'heure de création et l'heure du dernier accès d'une session. Nous associerions une nouvelle session à la demande s'il n'en existe pas déjà une.

<%@ page import = "java.io.*,java.util.*" %>
<%
   // Get session creation time.
   Date createTime = new Date(session.getCreationTime());
   
   // Get last access time of this Webpage.
   Date lastAccessTime = new Date(session.getLastAccessedTime());

   String title = "Welcome Back to my website";
   Integer visitCount = new Integer(0);
   String visitCountKey = new String("visitCount");
   String userIDKey = new String("userID");
   String userID = new String("ABCD");

   // Check if this is new comer on your Webpage.
   if (session.isNew() ){
      title = "Welcome to my website";
      session.setAttribute(userIDKey, userID);
      session.setAttribute(visitCountKey,  visitCount);
   } 
   visitCount = (Integer)session.getAttribute(visitCountKey);
   visitCount = visitCount + 1;
   userID = (String)session.getAttribute(userIDKey);
   session.setAttribute(visitCountKey,  visitCount);
%>

<html>
   <head>
      <title>Session Tracking</title>
   </head>
   
   <body>
      <center>
         <h1>Session Tracking</h1>
      </center>
      
      <table border = "1" align = "center"> 
         <tr bgcolor = "#949494">
            <th>Session info</th>
            <th>Value</th>
         </tr> 
         <tr>
            <td>id</td>
            <td><% out.print( session.getId()); %></td>
         </tr> 
         <tr>
            <td>Creation Time</td>
            <td><% out.print(createTime); %></td>
         </tr> 
         <tr>
            <td>Time of Last Access</td>
            <td><% out.print(lastAccessTime); %></td>
         </tr> 
         <tr>
            <td>User ID</td>
            <td><% out.print(userID); %></td>
         </tr> 
         <tr>
            <td>Number of visits</td>
            <td><% out.print(visitCount); %></td>
         </tr> 
      </table> 
   
   </body>
</html>

Maintenant, mettez le code ci-dessus dans main.jsp et essayez d'accéder http://localhost:8080/main.jsp. Une fois que vous exécutez l'URL, vous recevrez le résultat suivant -

Bienvenue sur mon site web

Session Information

Informations sur la session valeur
id 0AE3EC93FF44E3C525B4351B77ABB2D5
Temps de creation Mar 08 juin 17:26:40 GMT + 04: 00 2010
Heure du dernier accès Mar 08 juin 17:26:40 GMT + 04: 00 2010
Identifiant d'utilisateur A B C D
Nombre de visites 0

Maintenant, essayez d'exécuter le même JSP pour la deuxième fois, vous recevrez le résultat suivant.

Bienvenue sur mon site Web

Session Information

type d'information valeur
id 0AE3EC93FF44E3C525B4351B77ABB2D5
Temps de creation Mar 08 juin 17:26:40 GMT + 04: 00 2010
Heure du dernier accès Mar 08 juin 17:26:40 GMT + 04: 00 2010
Identifiant d'utilisateur A B C D
Nombre de visites 1

Suppression des données de session

Lorsque vous avez terminé avec les données de session d'un utilisateur, vous avez plusieurs options -

  • Remove a particular attribute - Vous pouvez appeler le public void removeAttribute(String name) pour supprimer la valeur associée à une clé particulière.

  • Delete the whole session - Vous pouvez appeler le public void invalidate() méthode pour supprimer une session entière.

  • Setting Session timeout - Vous pouvez appeler le public void setMaxInactiveInterval(int interval) pour définir le délai d'expiration d'une session individuellement.

  • Log the user out - Les serveurs prenant en charge les servlets 2.4, vous pouvez appeler logout pour déconnecter le client du serveur Web et invalider toutes les sessions appartenant à tous les utilisateurs.

  • web.xml Configuration - Si vous utilisez Tomcat, en dehors des méthodes mentionnées ci-dessus, vous pouvez configurer le délai d'expiration de la session dans le fichier web.xml comme suit.

<session-config>
   <session-timeout>15</session-timeout>
</session-config>

Le délai d'expiration est exprimé en minutes et remplace le délai par défaut qui est de 30 minutes dans Tomcat.

le getMaxInactiveInterval( )dans un servlet renvoie le délai d'expiration de cette session en secondes. Donc, si votre session est configurée en web.xml pendant 15 minutes,getMaxInactiveInterval( ) renvoie 900.

Dans ce chapitre, nous aborderons le téléchargement de fichiers dans JSP. Une JSP peut être utilisée avec une balise de formulaire HTML pour permettre aux utilisateurs de télécharger des fichiers sur le serveur. Un fichier téléchargé peut être un fichier texte ou un fichier binaire ou image ou n'importe quel document.

Création d'un formulaire de téléchargement de fichier

Voyons maintenant comment créer un formulaire de téléchargement de fichier. Le code HTML suivant crée un formulaire de téléchargement. Voici les points importants à noter -

  • La forme method l'attribut doit être défini sur POST La méthode et la méthode GET ne peuvent pas être utilisées.

  • La forme enctype l'attribut doit être défini sur multipart/form-data.

  • La forme actionL'attribut doit être défini sur un fichier JSP qui gérerait le téléchargement de fichiers sur le serveur principal. L'exemple suivant utiliseuploadFile.jsp fichier programme pour télécharger le fichier.

  • Pour télécharger un seul fichier, vous devez utiliser un seul <input .../> balise avec attribut type = "file". Pour autoriser le téléchargement de plusieurs fichiers, incluez plus d'une balise d'entrée avec des valeurs différentes pour l'attribut de nom. Le navigateur associe un bouton Parcourir à chacun d'eux.

<html>
   <head>
      <title>File Uploading Form</title>
   </head>
   
   <body>
      <h3>File Upload:</h3>
      Select a file to upload: <br />
      <form action = "UploadServlet" method = "post"
         enctype = "multipart/form-data">
         <input type = "file" name = "file" size = "50" />
         <br />
         <input type = "submit" value = "Upload File" />
      </form>
   </body>
   
</html>

Cela affichera le résultat suivant. Vous pouvez maintenant sélectionner un fichier à partir du PC local et lorsque l'utilisateur clique sur "Télécharger le fichier", le formulaire est soumis avec le fichier sélectionné -

File Upload

Select a file to upload −



NOTE - Le formulaire ci-dessus est juste un formulaire factice et ne fonctionnerait pas, vous devriez essayer le code ci-dessus sur votre machine pour le faire fonctionner.

Ecrire un script JSP backend

Définissons maintenant un emplacement où les fichiers téléchargés seront stockés. Vous pouvez le coder en dur dans votre programme ou ce nom de répertoire peut également être ajouté à l'aide d'une configuration externe telle qu'uncontext-param élément dans web.xml comme suit -

<web-app>
....
<context-param> 
   <description>Location to store uploaded file</description> 
   <param-name>file-upload</param-name> 
   <param-value>
      c:\apache-tomcat-5.5.29\webapps\data\
   </param-value> 
</context-param>
....
</web-app>

Voici le code source de UploadFile.jsp. Cela peut gérer le téléchargement de plusieurs fichiers à la fois. Considérons maintenant ce qui suit avant de procéder au téléchargement des fichiers.

  • L'exemple suivant dépend de FileUpload; assurez-vous d'avoir la dernière version decommons-fileupload.x.x.jarfichier dans votre chemin de classe. Vous pouvez le télécharger surhttps://commons.apache.org/fileupload/.

  • FileUpload dépend de Commons IO; assurez-vous d'avoir la dernière version decommons-io-x.x.jarfichier dans votre chemin de classe. Vous pouvez le télécharger surhttps://commons.apache.org/io/.

  • Lors du test de l'exemple suivant, vous devez télécharger un fichier dont la taille est inférieure à maxFileSize, sinon le fichier ne sera pas téléchargé.

  • Assurez-vous d'avoir créé des répertoires c:\temp et c:\apache-tomcat5.5.29\webapps\data bien à l'avance.

<%@ page import = "java.io.*,java.util.*, javax.servlet.*" %>
<%@ page import = "javax.servlet.http.*" %>
<%@ page import = "org.apache.commons.fileupload.*" %>
<%@ page import = "org.apache.commons.fileupload.disk.*" %>
<%@ page import = "org.apache.commons.fileupload.servlet.*" %>
<%@ page import = "org.apache.commons.io.output.*" %>

<%
   File file ;
   int maxFileSize = 5000 * 1024;
   int maxMemSize = 5000 * 1024;
   ServletContext context = pageContext.getServletContext();
   String filePath = context.getInitParameter("file-upload");

   // Verify the content type
   String contentType = request.getContentType();
   
   if ((contentType.indexOf("multipart/form-data") >= 0)) {
      DiskFileItemFactory factory = new DiskFileItemFactory();
      // maximum size that will be stored in memory
      factory.setSizeThreshold(maxMemSize);
      
      // Location to save data that is larger than maxMemSize.
      factory.setRepository(new File("c:\\temp"));

      // Create a new file upload handler
      ServletFileUpload upload = new ServletFileUpload(factory);
      
      // maximum file size to be uploaded.
      upload.setSizeMax( maxFileSize );
      
      try { 
         // Parse the request to get file items.
         List fileItems = upload.parseRequest(request);

         // Process the uploaded file items
         Iterator i = fileItems.iterator();

         out.println("<html>");
         out.println("<head>");
         out.println("<title>JSP File upload</title>");  
         out.println("</head>");
         out.println("<body>");
         
         while ( i.hasNext () ) {
            FileItem fi = (FileItem)i.next();
            if ( !fi.isFormField () ) {
               // Get the uploaded file parameters
               String fieldName = fi.getFieldName();
               String fileName = fi.getName();
               boolean isInMemory = fi.isInMemory();
               long sizeInBytes = fi.getSize();
            
               // Write the file
               if( fileName.lastIndexOf("\\") >= 0 ) {
                  file = new File( filePath + 
                  fileName.substring( fileName.lastIndexOf("\\"))) ;
               } else {
                  file = new File( filePath + 
                  fileName.substring(fileName.lastIndexOf("\\")+1)) ;
               }
               fi.write( file ) ;
               out.println("Uploaded Filename: " + filePath + 
               fileName + "<br>");
            }
         }
         out.println("</body>");
         out.println("</html>");
      } catch(Exception ex) {
         System.out.println(ex);
      }
   } else {
      out.println("<html>");
      out.println("<head>");
      out.println("<title>Servlet upload</title>");  
      out.println("</head>");
      out.println("<body>");
      out.println("<p>No file uploaded</p>"); 
      out.println("</body>");
      out.println("</html>");
   }
%>

Essayez maintenant de télécharger des fichiers à l'aide du formulaire HTML que vous avez créé ci-dessus. Quand tu essaieshttp://localhost:8080/UploadFile.htm, il affichera le résultat suivant. Cela vous aidera à télécharger n'importe quel fichier depuis votre machine locale.

File Upload

Select a file to upload −


Si votre script JSP fonctionne correctement, votre fichier doit être téléchargé dans c:\apache-tomcat5.5.29\webapps\data\ annuaire.

Dans ce chapitre, nous verrons comment gérer les données dans JSP. L'un des avantages les plus importants de l'utilisation de JSP est que vous pouvez utiliser toutes les méthodes disponibles dans le noyau Java. Nous allons vous guider à travers leDate classe qui est disponible dans le java.utilpaquet; cette classe encapsule la date et l'heure actuelles.

La classe Date prend en charge deux constructeurs. Le premier constructeur initialise l'objet avec la date et l'heure actuelles.

Date( )

Le constructeur suivant accepte un argument égal au nombre de millisecondes écoulées depuis le 1er janvier 1970 à minuit.

Date(long millisec)

Une fois que vous avez un objet Date disponible, vous pouvez appeler l'une des méthodes de support suivantes pour jouer avec les dates -

S.No. Méthodes et description
1

boolean after(Date date)

Renvoie true si l'objet Date appelant contient une date postérieure à celle spécifiée par date, sinon, elle renvoie false.

2

boolean before(Date date)

Renvoie true si l'objet Date appelant contient une date antérieure à celle spécifiée par date, sinon, elle renvoie false.

3

Object clone( )

Duplique l'objet Date appelant.

4

int compareTo(Date date)

Compare la valeur de l'objet appelant avec celle de date. Renvoie 0 si les valeurs sont égales. Renvoie une valeur négative si l'objet appelant est antérieur à la date. Renvoie une valeur positive si l'objet appelant est postérieur à la date.

5

int compareTo(Object obj)

Fonctionne de la même manière que compareTo (Date) si obj est de classe Date. Sinon, il lève une ClassCastException.

6

boolean equals(Object date)

Renvoie true si l'objet Date appelant contient la même heure et la même date que celles spécifiées par date, sinon, il renvoie false.

sept

long getTime( )

Renvoie le nombre de millisecondes qui se sont écoulées depuis le 1er janvier 1970.

8

int hashCode( )

Renvoie un code de hachage pour l'objet appelant.

9

void setTime(long time)

Définit l'heure et la date comme spécifié par time, qui représente un temps écoulé en millisecondes à partir du 1er janvier 1970 à minuit

dix

String toString( )

Convertit l'objet Date appelant en une chaîne et renvoie le résultat.

Obtenir la date et l'heure actuelles

Avec le programme JSP, il est très facile d'obtenir la date et l'heure actuelles. Vous pouvez utiliser un objet Date simple avec letoString() méthode pour imprimer la date et l'heure actuelles comme suit -

<%@ page import = "java.io.*,java.util.*, javax.servlet.*" %>

<html>
   <head>
      <title>Display Current Date & Time</title>
   </head>
   
   <body>
      <center>
         <h1>Display Current Date & Time</h1>
      </center>
      <%
         Date date = new Date();
         out.print( "<h2 align = \"center\">" +date.toString()+"</h2>");
      %>
   </body>
</html>

Gardons maintenant le code dans CurrentDate.jsp puis appelez cette JSP en utilisant l'URL http://localhost:8080/CurrentDate.jsp. Vous recevrez le résultat suivant -

Display Current Date & Time

Mon Jun 21 21:46:49 GMT+04:00 2010

Actualisez la page avec URL http://localhost:8080/CurrentDate.jsp. Vous trouverez une différence en quelques secondes à chaque fois que vous actualisez.

Comparaison des dates

Comme indiqué dans les sections précédentes, vous pouvez utiliser toutes les méthodes Java disponibles dans vos scripts JSP. Au cas où vous auriez besoin de comparer deux dates, envisagez les méthodes suivantes -

  • Vous pouvez utiliser getTime( ) pour obtenir le nombre de millisecondes qui se sont écoulées depuis le 1er janvier 1970 à minuit pour les deux objets, puis comparer ces deux valeurs.

  • Vous pouvez utiliser les méthodes before( ), after( ), et equals( )parce que le 12 du mois précède le 18; par exemple,new Date(99, 2, 12).before(new Date (99, 2, 18)) renvoie vrai.

  • Vous pouvez utiliser le compareTo( )méthode; cette méthode est définie par leComparable interface et mis en œuvre par Date.

Formatage de la date à l'aide de SimpleDateFormat

SimpleDateFormat est une classe concrète pour le formatage et l'analyse des dates d'une manière sensible aux paramètres régionaux. SimpleDateFormat vous permet de commencer par choisir les modèles définis par l'utilisateur pour le formatage de la date et de l'heure.

Modifions l'exemple ci-dessus comme suit -

<%@ page import = "java.io.*,java.util.*" %>
<%@ page import = "javax.servlet.*,java.text.*" %>

<html>
   <head>
      <title>Display Current Date & Time</title>
   </head>
   
   <body>
      <center>
         <h1>Display Current Date & Time</h1>
      </center>
      <%
         Date dNow = new Date( );
         SimpleDateFormat ft = 
         new SimpleDateFormat ("E yyyy.MM.dd 'at' hh:mm:ss a zzz");
         out.print( "<h2 align=\"center\">" + ft.format(dNow) + "</h2>");
      %>
   </body>
</html>

Compilez à nouveau le servlet ci-dessus, puis appelez ce servlet en utilisant l'URL http://localhost:8080/CurrentDate. Vous recevrez le résultat suivant -

Display Current Date & Time

Mon 2010.06.21 at 10:06:44 PM GMT+04:00

Codes de format de format de date simples

Pour spécifier le format d'heure, utilisez une chaîne de modèle d'heure. Dans ce modèle, toutes les lettres ASCII sont réservées en tant que lettres de modèle, qui sont définies comme suit -

Personnage La description Exemple
g Désignation de l'époque UN D
y L'année en quatre chiffres 2001
M Mois dans l'année Juillet ou 07
Jour dans le mois 0
h Heure en AM / PM (1 ~ 12) 2
H Heure dans la journée (0 ~ 23) 22
m Minute en heure 30
s Seconde en minute 55
S Milliseconde 234
E Jour en semaine Mardi
Jour dans l'année 360
F Jour de la semaine dans le mois 2 (deuxième mercredi de juillet)
w Semaine dans l'année 40
W Semaine en mois
une Marqueur AM / PM PM
k Heure dans la journée (1 ~ 24) 24
K Heure en AM / PM (0 ~ 11) 0
z Fuseau horaire Heure normale de l'Est
' Échapper pour le texte Délimiteur
" Simple citation »

Pour une liste complète des méthodes constantes disponibles pour manipuler la date, vous pouvez vous référer à la documentation Java standard.

Dans ce chapitre, nous aborderons la redirection de page avec JSP. La redirection de page est généralement utilisée lorsqu'un document est déplacé vers un nouvel emplacement et que nous devons envoyer le client vers ce nouvel emplacement. Cela peut être dû à l'équilibrage de charge ou à une simple randomisation.

Le moyen le plus simple de rediriger une requête vers une autre page consiste à utiliser sendRedirect()méthode de l'objet de réponse. Voici la signature de cette méthode -

public void response.sendRedirect(String location)
throws IOException

Cette méthode renvoie la réponse au navigateur avec le code d'état et le nouvel emplacement de la page. Vous pouvez également utiliser lesetStatus() et le setHeader() méthodes ensemble pour obtenir le même exemple de redirection -

....
String site = "http://www.newpage.com" ;
response.setStatus(response.SC_MOVED_TEMPORARILY);
response.setHeader("Location", site); 
....

Exemple

Cet exemple montre comment une JSP effectue la redirection de page vers un autre emplacement -

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>Page Redirection</title>
   </head>
   
   <body>
      <center>
         <h1>Page Redirection</h1>
      </center>
      <%
         // New location to be redirected
         String site = new String("http://www.photofuntoos.com");
         response.setStatus(response.SC_MOVED_TEMPORARILY);
         response.setHeader("Location", site); 
      %>
   </body>
</html>

Mettons maintenant le code ci-dessus dans PageRedirect.jsp et appelons cette JSP en utilisant l'URL http://localhost:8080/PageRedirect.jsp. Cela vous mènerait à l'URL donnéehttp://www.photofuntoos.com.

Dans ce chapitre, nous aborderons Hits Counter dans JSP. Un compteur d'accès vous indique le nombre de visites sur une page particulière de votre site Web. Habituellement, vous attachez un compteur d'accès à votre page index.jsp en supposant que les gens arrivent d'abord sur votre page d'accueil.

Pour implémenter un compteur d'accès, vous pouvez utiliser l'objet Application implicite et les méthodes associées getAttribute() et setAttribute().

Cet objet est une représentation de la page JSP tout au long de son cycle de vie. Cet objet est créé lorsque la page JSP est initialisée et sera supprimé lorsque la page JSP sera supprimée par lejspDestroy() méthode.

Voici la syntaxe pour définir une variable au niveau de l'application -

application.setAttribute(String Key, Object Value);

Vous pouvez utiliser la méthode ci-dessus pour définir une variable de compteur d'accès et pour réinitialiser la même variable. Voici la méthode pour lire la variable définie par la méthode précédente -

application.getAttribute(String Key);

Chaque fois qu'un utilisateur accède à votre page, vous pouvez lire la valeur actuelle du compteur d'accès et l'augmenter de un et la définir à nouveau pour une utilisation future.

Exemple

Cet exemple montre comment vous pouvez utiliser JSP pour compter le nombre total d'appels sur une page particulière. Si vous souhaitez compter le nombre total de visites de votre site Web, vous devrez inclure le même code dans toutes les pages JSP.

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>Application object in JSP</title>
   </head>
   
   <body>
      <%
         Integer hitsCount = (Integer)application.getAttribute("hitCounter");
         if( hitsCount ==null || hitsCount == 0 ) {
            /* First visit */
            out.println("Welcome to my website!");
            hitsCount = 1;
         } else {
            /* return visit */
            out.println("Welcome back to my website!");
            hitsCount += 1;
         }
         application.setAttribute("hitCounter", hitsCount);
      %>
      <center>
         <p>Total number of visits: <%= hitsCount%></p>
      </center>
   
   </body>
</html>

Mettons maintenant le code ci-dessus dans main.jsp et appelez cette JSP en utilisant l'URL http://localhost:8080/main.jsp. Cela affichera la valeur du compteur d'accès qui augmente au fur et à mesure que vous actualisez la page. Vous pouvez essayer d'accéder à la page en utilisant différents navigateurs et vous constaterez que le compteur d'accès continuera d'augmenter à chaque appel et vous recevrez le résultat comme suit -

Welcome back to my website!

Total number of visits: 12

Réinitialisation du compteur de coups

Que faire lorsque vous redémarrez votre application, c'est-à-dire le serveur Web, cela réinitialisera votre variable d'application et votre compteur se remettra à zéro. Pour éviter cette perte, tenez compte des points suivants -

  • Définissez une table de base de données avec un seul comptage, disons hitcount. Attribuez-lui une valeur nulle.

  • À chaque appel, lisez le tableau pour obtenir la valeur de hitcount.

  • Augmentez la valeur de hitcount de un et mettez à jour la table avec une nouvelle valeur.

  • Afficher la nouvelle valeur de hitcount en tant que nombre total de visites sur la page.

  • Si vous souhaitez compter les appels pour toutes les pages, implémentez la logique ci-dessus pour toutes les pages.

Dans ce chapitre, nous aborderons l'actualisation automatique dans JSP. Considérez une page Web qui affiche le score du match en direct ou l'état de la bourse ou la ration de change. Pour tous ces types de pages, vous devez actualiser régulièrement votre page Web en utilisant le bouton d'actualisation ou de rechargement de votre navigateur.

JSP facilite ce travail en vous fournissant un mécanisme dans lequel vous pouvez créer une page Web de manière à ce qu'elle s'actualise automatiquement après un intervalle donné.

Le moyen le plus simple d'actualiser une page Web consiste à utiliser setIntHeader()méthode de l'objet de réponse. Voici la signature de cette méthode -

public void setIntHeader(String header, int headerValue)

Cette méthode renvoie l'en-tête "Refresh" au navigateur avec une valeur entière qui indique l'intervalle de temps en secondes.

Exemple d'actualisation automatique de la page

Dans l'exemple suivant, nous utiliserons le setIntHeader() méthode à définir Refreshentête. Cela aidera à simuler une horloge numérique -

<%@ page import = "java.io.*,java.util.*" %>

<html>
   <head>
      <title>Auto Refresh Header Example</title>
   </head>
   
   <body>
      <center>
         <h2>Auto Refresh Header Example</h2>
         <%
            // Set refresh, autoload time as 5 seconds
            response.setIntHeader("Refresh", 5);
            
            // Get current time
            Calendar calendar = new GregorianCalendar();
            String am_pm;
            
            int hour = calendar.get(Calendar.HOUR);
            int minute = calendar.get(Calendar.MINUTE);
            int second = calendar.get(Calendar.SECOND);
            
            if(calendar.get(Calendar.AM_PM) == 0)
               am_pm = "AM";
            else
               am_pm = "PM";
            String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
            out.println("Crrent Time: " + CT + "\n");
         %>
      </center>
   
   </body>
</html>

Maintenant, mettez le code ci-dessus dans main.jspet essayez d'y accéder. Ceci affichera l'heure actuelle du système toutes les 5 secondes comme suit. Exécutez simplement le JSP et attendez de voir le résultat -

Auto Refresh Header Example

Current Time is: 9:44:50 PM

Dans ce chapitre, nous verrons comment envoyer des e-mails à l'aide de JSP. Pour envoyer un e-mail à l'aide d'un JSP, vous devez disposer duJavaMail API et le Java Activation Framework (JAF) installé sur votre machine.

  • Vous pouvez télécharger la dernière version de JavaMail (version 1.2) à partir du site Web standard de Java.

  • Vous pouvez télécharger la dernière version de JavaBeans Activation Framework JAF (version 1.0.2) à partir du site Web standard de Java.

Téléchargez et décompressez ces fichiers, dans les répertoires de niveau supérieur nouvellement créés. Vous trouverez un certain nombre de fichiers jar pour les deux applications. Vous devez ajouter lemail.jar et le activation.jar fichiers dans votre CLASSPATH.

Envoyer un e-mail simple

Voici un exemple pour envoyer un simple e-mail depuis votre machine. On suppose que votrelocalhostest connecté à Internet et qu'il est suffisamment capable d'envoyer un e-mail. Assurez-vous que tous les fichiers jar du package Java Email API et du package JAF sont disponibles dans CLASSPATH.

<%@ page import = "java.io.*,java.util.*,javax.mail.*"%>
<%@ page import = "javax.mail.internet.*,javax.activation.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>

<%
   String result;
   
   // Recipient's email ID needs to be mentioned.
   String to = "[email protected]";

   // Sender's email ID needs to be mentioned
   String from = "[email protected]";

   // Assuming you are sending email from localhost
   String host = "localhost";

   // Get system properties object
   Properties properties = System.getProperties();

   // Setup mail server
   properties.setProperty("mail.smtp.host", host);

   // Get the default Session object.
   Session mailSession = Session.getDefaultInstance(properties);

   try {
      // Create a default MimeMessage object.
      MimeMessage message = new MimeMessage(mailSession);
      
      // Set From: header field of the header.
      message.setFrom(new InternetAddress(from));
      
      // Set To: header field of the header.
      message.addRecipient(Message.RecipientType.TO,
                               new InternetAddress(to));
      // Set Subject: header field
      message.setSubject("This is the Subject Line!");
      
      // Now set the actual message
      message.setText("This is actual message");
      
      // Send message
      Transport.send(message);
      result = "Sent message successfully....";
   } catch (MessagingException mex) {
      mex.printStackTrace();
      result = "Error: unable to send message....";
   }
%>

<html>
   <head>
      <title>Send Email using JSP</title>
   </head>
   
   <body>
      <center>
         <h1>Send Email using JSP</h1>
      </center>
      
      <p align = "center">
         <% 
            out.println("Result: " + result + "\n");
         %>
      </p>
   </body>
</html>

Mettons maintenant le code ci-dessus dans SendEmail.jsp fichier et appelez cette JSP en utilisant l'URL http://localhost:8080/SendEmail.jsp. Cela aidera à envoyer un e-mail à l'ID de messagerie donné[email protected]. Vous recevrez la réponse suivante -

Send Email using JSP

Result: Sent message successfully....

Si vous souhaitez envoyer un e-mail à plusieurs destinataires, utilisez les méthodes suivantes pour spécifier plusieurs ID d'e-mail:

void addRecipients(Message.RecipientType type, Address[] addresses)
throws MessagingException

Voici la description des paramètres -

  • type- Ce serait réglé sur TO, CC ou BCC. Ici, CC représente Carbon Copy et BCC représente Black Carbon Copy. Exemple de Message.RecipientType.TO

  • addresses- Ceci est le tableau des identifiants de messagerie. Vous devrez utiliser la méthode InternetAddress () lors de la spécification des identifiants de messagerie

Envoyer un e-mail HTML

Voici un exemple pour envoyer un e-mail HTML depuis votre machine. On suppose que votrelocalhostest connecté à Internet et qu'il est suffisamment capable d'envoyer un e-mail. Assurez-vous que tous les fichiers jar duJava Email API package et le JAF package sont disponibles dans CLASSPATH.

Cet exemple est très similaire au précédent, sauf qu'ici nous utilisons le setContent() méthode pour définir le contenu dont le deuxième argument est "text/html" pour spécifier que le contenu HTML est inclus dans le message.

En utilisant cet exemple, vous pouvez envoyer un contenu HTML aussi volumineux que nécessaire.

<%@ page import = "java.io.*,java.util.*,javax.mail.*"%>
<%@ page import = "javax.mail.internet.*,javax.activation.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>

<%
   String result;
   
   // Recipient's email ID needs to be mentioned.
   String to = "[email protected]";

   // Sender's email ID needs to be mentioned
   String from = "[email protected]";

   // Assuming you are sending email from localhost
   String host = "localhost";

   // Get system properties object
   Properties properties = System.getProperties();

   // Setup mail server
   properties.setProperty("mail.smtp.host", host);

   // Get the default Session object.
   Session mailSession = Session.getDefaultInstance(properties);

   try {
      // Create a default MimeMessage object.
      MimeMessage message = new MimeMessage(mailSession);
      
      // Set From: header field of the header.
      message.setFrom(new InternetAddress(from));
      
      // Set To: header field of the header.
      message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));
      
      // Set Subject: header field
      message.setSubject("This is the Subject Line!");
     
      // Send the actual HTML message, as big as you like
      message.setContent("<h1>This is actual message</h1>", "text/html" );
      
      // Send message
      Transport.send(message);
      result = "Sent message successfully....";
   } catch (MessagingException mex) {
      mex.printStackTrace();
      result = "Error: unable to send message....";
   }
%>

<html>
   <head>
      <title>Send HTML Email using JSP</title>
   </head>

   <body>
      <center>
         <h1>Send Email using JSP</h1>
      </center>
      
      <p align = "center">
         <% 
            out.println("Result: " + result + "\n");
         %>
      </p>
   </body>
</html>

Utilisons maintenant le JSP ci-dessus pour envoyer un message HTML sur un identifiant de messagerie donné.

Envoyer la pièce jointe par e-mail

Voici un exemple pour envoyer un e-mail avec pièce jointe à partir de votre machine -

<%@ page import = "java.io.*,java.util.*,javax.mail.*"%>
<%@ page import = "javax.mail.internet.*,javax.activation.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>

<%
   String result;
   
   // Recipient's email ID needs to be mentioned.
   String to = "[email protected]";

   // Sender's email ID needs to be mentioned
   String from = "[email protected]";

   // Assuming you are sending email from localhost
   String host = "localhost";

   // Get system properties object
   Properties properties = System.getProperties();

   // Setup mail server
   properties.setProperty("mail.smtp.host", host);

   // Get the default Session object.
   Session mailSession = Session.getDefaultInstance(properties);

   try {
      // Create a default MimeMessage object.
      MimeMessage message = new MimeMessage(mailSession);

      // Set From: header field of the header.
      message.setFrom(new InternetAddress(from));

      // Set To: header field of the header.
      message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));

      // Set Subject: header field
      message.setSubject("This is the Subject Line!");

      // Create the message part 
      BodyPart messageBodyPart = new MimeBodyPart();

      // Fill the message
      messageBodyPart.setText("This is message body");
      
      // Create a multipart message
      Multipart multipart = new MimeMultipart();

      // Set text message part
      multipart.addBodyPart(messageBodyPart);

      // Part two is attachment
      messageBodyPart = new MimeBodyPart();
      
      String filename = "file.txt";
      DataSource source = new FileDataSource(filename);
      messageBodyPart.setDataHandler(new DataHandler(source));
      messageBodyPart.setFileName(filename);
      multipart.addBodyPart(messageBodyPart);

      // Send the complete message parts
      message.setContent(multipart );

      // Send message
      Transport.send(message);
      String title = "Send Email";
      result = "Sent message successfully....";
   } catch (MessagingException mex) {
      mex.printStackTrace();
      result = "Error: unable to send message....";
   }
%>

<html>
   <head>
      <title>Send Attachment Email using JSP</title>
   </head>
   
   <body>
      <center>
         <h1>Send Attachment Email using JSP</h1>
      </center>
      
      <p align = "center">
         <%out.println("Result: " + result + "\n");%>
      </p>
   </body>
</html>

Exécutons maintenant le JSP ci-dessus pour envoyer un fichier en tant que pièce jointe avec un message sur un identifiant de messagerie donné.

Partie d'authentification utilisateur

S'il est nécessaire de fournir un ID utilisateur et un mot de passe au serveur de messagerie à des fins d'authentification, vous pouvez définir ces propriétés comme suit:

props.setProperty("mail.user", "myuser");
props.setProperty("mail.password", "mypwd");

Le reste du mécanisme d'envoi de courrier électronique restera tel qu'expliqué ci-dessus.

Utilisation de formulaires pour envoyer des e-mails

Vous pouvez utiliser le formulaire HTML pour accepter les paramètres d'e-mail, puis vous pouvez utiliser le request objet pour obtenir toutes les informations comme suit -

String to = request.getParameter("to");
String from = request.getParameter("from");
String subject = request.getParameter("subject");
String messageText = request.getParameter("body");

Une fois que vous avez toutes les informations, vous pouvez utiliser les programmes mentionnés ci-dessus pour envoyer des e-mails.

Dans ce chapitre, nous allons comprendre les différentes balises dans JSP. La bibliothèque de balises standard JavaServer Pages (JSTL) est une collection de balises JSP utiles qui encapsulent les fonctionnalités de base communes à de nombreuses applications JSP.

JSTL prend en charge les tâches structurelles courantes telles que l'itération et les conditions, les balises pour manipuler les documents XML, les balises d'internationalisation et les balises SQL. Il fournit également un cadre pour l'intégration des balises personnalisées existantes avec les balises JSTL.

Installer la bibliothèque JSTL

Pour commencer à travailler avec les tages JSP, vous devez d'abord installer la bibliothèque JSTL. Si vous utilisez le conteneur Apache Tomcat, suivez ces deux étapes -

Step 1- Téléchargez la distribution binaire depuis Apache Standard Taglib et décompressez le fichier compressé.

Step 2 - Pour utiliser le Taglib Standard depuis son Jakarta Taglibs distribution, copiez simplement les fichiers JAR dans le répertoire 'lib' de la distribution dans votre application webapps\ROOT\WEB-INF\lib annuaire.

Pour utiliser l'une des bibliothèques, vous devez inclure une directive <taglib> en haut de chaque JSP qui utilise la bibliothèque.

Classification des balises JSTL

Les balises JSTL peuvent être classées, en fonction de leurs fonctions, dans les groupes de bibliothèques de balises JSTL suivants qui peuvent être utilisés lors de la création d'une page JSP -

  • Core Tags

  • Formatting tags

  • SQL tags

  • XML tags

  • JSTL Functions

Balises principales

Le groupe principal de balises est constitué des balises JSTL les plus couramment utilisées. Voici la syntaxe pour inclure la bibliothèque JSTL Core dans votre JSP -

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

Le tableau suivant répertorie les balises JSTL principales -

S.No. Balise et description
1

Comme <% = ...>, mais pour les expressions.

2

Définit le résultat d'une évaluation d'expression dans un 'scope'

3

Supprime un scoped variable (à partir d'une portée particulière, si spécifié).

4

Attrape tout Throwable qui se produit dans son corps et l'expose éventuellement.

5

Balise conditionnelle simple qui évalue son corps si la condition fournie est vraie.

6

Balise conditionnelle simple qui établit un contexte pour les opérations conditionnelles mutuellement exclusives, marquées par <when> et <otherwise>.

sept

Sous-étiquette de <choose> qui inclut son corps si sa condition est évaluée à 'true'.

8

Sous-étiquette de <choose> qui suit le <when> balise et s'exécute uniquement si toutes les conditions antérieures évaluées à 'false'.

9

Récupère une URL absolue ou relative et expose son contenu à la page, une chaîne dans 'var', ou un lecteur dans 'varReader'.

dix

La balise d'itération de base, acceptant de nombreux types de collection différents et prenant en charge le sous-ensemble et d'autres fonctionnalités.

11

Itère sur les jetons, séparés par les délimètres fournis.

12

Ajoute un paramètre à un conteneur 'import' URL de la balise.

13

Redirige vers une nouvelle URL.

14

Crée une URL avec des paramètres de requête facultatifs

Mise en forme des balises

Les balises de mise en forme JSTL sont utilisées pour formater et afficher le texte, la date, l'heure et les nombres des sites Web internationalisés. Voici la syntaxe pour inclure la bibliothèque de mise en forme dans votre JSP -

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

Le tableau suivant répertorie les balises JSTL de formatage -

S.No. Balise et description
1

Pour rendre une valeur numérique avec une précision ou un format spécifique.

2

Analyse la représentation sous forme de chaîne d'un nombre, d'une devise ou d'un pourcentage.

3

Formate une date et / ou une heure à l'aide des styles et motifs fournis.

4

Analyse la représentation sous forme de chaîne d'une date et / ou d'une heure

5

Charge un ensemble de ressources à utiliser par son corps de balise.

6

Stocke les paramètres régionaux donnés dans la variable de configuration des paramètres régionaux.

sept

Charge un ensemble de ressources et le stocke dans la variable de portée nommée ou la variable de configuration de l'ensemble.

8

Spécifie le fuseau horaire pour toutes les actions de mise en forme ou d'analyse de l'heure imbriquées dans son corps.

9

Stocke le fuseau horaire donné dans la variable de configuration du fuseau horaire

dix

Affiche un message internationalisé.

11

Définit le codage des caractères de la demande

Balises SQL

La bibliothèque de balises SQL JSTL fournit des balises pour interagir avec des bases de données relationnelles (SGBDR) telles que Oracle, mySQL, ou Microsoft SQL Server.

Voici la syntaxe pour inclure la bibliothèque SQL JSTL dans votre JSP -

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

Le tableau suivant répertorie les balises SQL JSTL -

S.No. Balise et description
1

Crée un DataSource simple adapté uniquement au prototypage

2

Exécute la requête SQL définie dans son corps ou via l'attribut sql.

3

Exécute la mise à jour SQL définie dans son corps ou via l'attribut sql.

4

Définit un paramètre dans une instruction SQL sur la valeur spécifiée.

5

Définit un paramètre dans une instruction SQL sur la valeur java.util.Date spécifiée.

6

Fournit des éléments d'action de base de données imbriqués avec une connexion partagée, configurée pour exécuter toutes les instructions en une seule transaction.

Balises XML

Les balises XML JSTL fournissent une manière centrée sur JSP de créer et de manipuler les documents XML. Voici la syntaxe pour inclure la bibliothèque XML JSTL dans votre JSP.

La bibliothèque de balises XML JSTL possède des balises personnalisées pour interagir avec les données XML. Cela inclut l'analyse du XML, la transformation des données XML et le contrôle de flux basé sur les expressions XPath.

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

Avant de poursuivre avec les exemples, vous devrez copier les deux bibliothèques associées XML et XPath suivantes dans votre <Tomcat Installation Directory>\lib -

  • XercesImpl.jar - Téléchargez-le depuis https://www.apache.org/dist/xerces/j/

  • xalan.jar - Téléchargez-le depuis https://xml.apache.org/xalan-j/index.html

Voici la liste des balises XML JSTL -

S.No. Balise et description
1

Comme <% = ...>, mais pour les expressions XPath.

2

Utilisé pour analyser les données XML spécifiées via un attribut ou dans le corps de la balise.

3

Définit une variable sur la valeur d'une expression XPath.

4

Évalue une expression XPath de test et si elle est vraie, elle traite son corps. Si la condition de test est fausse, le corps est ignoré.

5

Pour boucler sur des nœuds dans un document XML.

6

Balise conditionnelle simple qui établit un contexte pour les opérations conditionnelles mutuellement exclusives, marquées par <when> et <otherwise> Mots clés.

sept

Sous-étiquette de <choose> cela inclut son corps si son expression est évaluée à «vrai».

8

Sous-étiquette de <choose> qui suit le <when> balise et s'exécute uniquement si toutes les conditions précédentes sont évaluées à «false».

9

Applique une transformation XSL à un document XML

dix

Utilisé avec le transform balise pour définir un paramètre dans la feuille de style XSLT

Fonctions JSTL

JSTL comprend un certain nombre de fonctions standard, dont la plupart sont des fonctions courantes de manipulation de chaînes. Voici la syntaxe pour inclure la bibliothèque de fonctions JSTL dans votre JSP -

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

Le tableau suivant répertorie les différentes fonctions JSTL -

S.No. Description de la fonction
1 fn: contient ()

Teste si une chaîne d'entrée contient la sous-chaîne spécifiée.

2 fn: containsIgnoreCase ()

Teste si une chaîne d'entrée contient la sous-chaîne spécifiée sans tenir compte de la casse.

3 fn: endsWith ()

Teste si une chaîne d'entrée se termine par le suffixe spécifié.

4 fn: escapeXml ()

Échappe les caractères pouvant être interprétés comme du balisage XML.

5 fn: indexOf ()

Renvoie l'index avec une chaîne de la première occurrence d'une sous-chaîne spécifiée.

6 fn: join ()

Joint tous les éléments d'un tableau dans une chaîne.

sept fn: longueur ()

Renvoie le nombre d'éléments dans une collection ou le nombre de caractères d'une chaîne.

8 fn: remplacer ()

Renvoie une chaîne résultant du remplacement dans une chaîne d'entrée de toutes les occurrences par une chaîne donnée.

9 fn: split ()

Divise une chaîne en un tableau de sous-chaînes.

dix fn: démarre avec ()

Teste si une chaîne d'entrée commence par le préfixe spécifié.

11 fn: sous-chaîne ()

Renvoie un sous-ensemble d'une chaîne.

12 fn: substringAfter ()

Renvoie un sous-ensemble d'une chaîne suivant une sous-chaîne spécifique.

13 fn: substringBefore ()

Renvoie un sous-ensemble d'une chaîne avant une sous-chaîne spécifique.

14 fn: toLowerCase ()

Convertit tous les caractères d'une chaîne en minuscules.

15 fn: toUpperCase ()

Convertit tous les caractères d'une chaîne en majuscules.

16 fn: trim ()

Supprime les espaces blancs aux deux extrémités d'une chaîne.

Dans ce chapitre, nous verrons comment accéder à la base de données avec JSP. Nous supposons que vous avez une bonne compréhension du fonctionnement de l'application JDBC. Avant de commencer avec l'accès à la base de données via un JSP, assurez-vous que vous disposez d'une configuration d'environnement JDBC appropriée avec une base de données.

Pour plus de détails sur l'accès à la base de données à l'aide de JDBC et la configuration de son environnement, vous pouvez consulter notre didacticiel JDBC .

Pour commencer avec le concept de base, créons une table et créons quelques enregistrements dans cette table comme suit -

Créer une table

Pour créer le Employees table dans la base de données EMP, utilisez les étapes suivantes -

Étape 1

Ouvrir un Command Prompt et passez au répertoire d'installation comme suit -

C:\>
C:\>cd Program Files\MySQL\bin
C:\Program Files\MySQL\bin>

Étape 2

Connectez-vous à la base de données comme suit -

C:\Program Files\MySQL\bin>mysql -u root -p
Enter password: ********
mysql>

Étape 3

Créer le Employee table dans le TEST base de données comme suit - -

mysql> use TEST;
mysql> create table Employees
   (
      id int not null,
      age int not null,
      first varchar (255),
      last varchar (255)
   );
Query OK, 0 rows affected (0.08 sec)
mysql>

Créer des enregistrements de données

Créons maintenant quelques enregistrements dans le Employee tableau comme suit - -

mysql> INSERT INTO Employees VALUES (100, 18, 'Zara', 'Ali');
Query OK, 1 row affected (0.05 sec)
 
mysql> INSERT INTO Employees VALUES (101, 25, 'Mahnaz', 'Fatma');
Query OK, 1 row affected (0.00 sec)
 
mysql> INSERT INTO Employees VALUES (102, 30, 'Zaid', 'Khan');
Query OK, 1 row affected (0.00 sec)
 
mysql> INSERT INTO Employees VALUES (103, 28, 'Sumit', 'Mittal');
Query OK, 1 row affected (0.00 sec)
 
mysql>

Opération SELECT

L'exemple suivant montre comment nous pouvons exécuter le SQL SELECT instruction utilisant JTSL dans la programmation JSP -

<%@ page import = "java.io.*,java.util.*,java.sql.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix = "c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix = "sql"%>
 
<html>
   <head>
      <title>SELECT Operation</title>
   </head>

   <body>
      <sql:setDataSource var = "snapshot" driver = "com.mysql.jdbc.Driver"
         url = "jdbc:mysql://localhost/TEST"
         user = "root"  password = "pass123"/>
 
      <sql:query dataSource = "${snapshot}" var = "result">
         SELECT * from Employees;
      </sql:query>
 
      <table border = "1" width = "100%">
         <tr>
            <th>Emp ID</th>
            <th>First Name</th>
            <th>Last Name</th>
            <th>Age</th>
         </tr>
         
         <c:forEach var = "row" items = "${result.rows}"> <tr> <td><c:out value = "${row.id}"/></td>
               <td><c:out value = "${row.first}"/></td> <td><c:out value = "${row.last}"/></td>
               <td><c:out value = "${row.age}"/></td>
            </tr>
         </c:forEach>
      </table>
 
   </body>
</html>

Accédez au JSP ci-dessus, le résultat suivant sera affiché -

Emp ID First Name Last Name Age
100 Zara Ali 18
101 Mahnaz Fatma 25
102 Zaid Khan 30
103 Sumit Mittal 28

Opération INSERT

L'exemple suivant montre comment nous pouvons exécuter l'instruction SQL INSERT en utilisant JTSL dans la programmation JSP -

<%@ page import = "java.io.*,java.util.*,java.sql.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix = "c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix = "sql"%>
 
<html>
   <head>
      <title>JINSERT Operation</title>
   </head>
   
   <body>
      <sql:setDataSource var = "snapshot" driver = "com.mysql.jdbc.Driver"
         url = "jdbc:mysql://localhost/TEST"
         user = "root"  password = "pass123"/>
         <sql:update dataSource = "${snapshot}" var = "result">
         INSERT INTO Employees VALUES (104, 2, 'Nuha', 'Ali');
      </sql:update>
 
      <sql:query dataSource = "${snapshot}" var = "result"> SELECT * from Employees; </sql:query> <table border = "1" width = "100%"> <tr> <th>Emp ID</th> <th>First Name</th> <th>Last Name</th> <th>Age</th> </tr> <c:forEach var = "row" items = "${result.rows}">
            <tr>
               <td><c:out value = "${row.id}"/></td> <td><c:out value = "${row.first}"/></td>
               <td><c:out value = "${row.last}"/></td> <td><c:out value = "${row.age}"/></td>
            </tr>
         </c:forEach>
      </table>
 
   </body>
</html>

Accédez au JSP ci-dessus, le résultat suivant sera affiché -

Emp ID First Name Last Name Age
100 Zara Ali 18
101 Mahnaz Fatma 25
102 Zaid Khan 30
103 Sumit Mittal 28
104 Nuha Ali 2

Effacer l'opération

L'exemple suivant montre comment nous pouvons exécuter le SQL DELETE instruction utilisant JTSL dans la programmation JSP -

<%@ page import = "java.io.*,java.util.*,java.sql.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix = "c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix = "sql"%>
 
<html>
   <head>
      <title>DELETE Operation</title>
   </head>
   
   <body>
      <sql:setDataSource var = "snapshot" driver = "com.mysql.jdbc.Driver"
         url = "jdbc:mysql://localhost/TEST"
         user = "root" password = "pass123"/>
 
      <c:set var = "empId" value = "103"/>
 
      <sql:update dataSource = "${snapshot}" var = "count"> DELETE FROM Employees WHERE Id = ? <sql:param value = "${empId}" />
      </sql:update>
 
      <sql:query dataSource = "${snapshot}" var = "result"> SELECT * from Employees; </sql:query> <table border = "1" width = "100%"> <tr> <th>Emp ID</th> <th>First Name</th> <th>Last Name</th> <th>Age</th> </tr> <c:forEach var = "row" items = "${result.rows}">
            <tr>
               <td><c:out value = "${row.id}"/></td> <td><c:out value = "${row.first}"/></td>
               <td><c:out value = "${row.last}"/></td> <td><c:out value = "${row.age}"/></td>
            </tr>
         </c:forEach>
      </table>
 
   </body>
</html>

Accédez au JSP ci-dessus, le résultat suivant sera affiché -

Emp ID First Name Last Name Age
100 Zara Ali 18
101 Mahnaz Fatma 25
102 Zaid Khan 30

Opération UPDATE

L'exemple suivant montre comment nous pouvons exécuter le SQL UPDATE instruction utilisant JTSL dans la programmation JSP -

<%@ page import = "java.io.*,java.util.*,java.sql.*"%>
<%@ page import = "javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri = "http://java.sun.com/jsp/jstl/core" prefix = "c"%>
<%@ taglib uri = "http://java.sun.com/jsp/jstl/sql" prefix = "sql"%>
 
<html>
   <head>
      <title>DELETE Operation</title>
   </head>
   
   <body>
      <sql:setDataSource var = "snapshot" driver = "com.mysql.jdbc.Driver"
         url = "jdbc:mysql://localhost/TEST"
         user = "root" password = "pass123"/>
 
      <c:set var = "empId" value = "102"/>
 
      <sql:update dataSource = "${snapshot}" var = "count"> UPDATE Employees SET WHERE last = 'Ali' <sql:param value = "${empId}" />
      </sql:update>
 
      <sql:query dataSource = "${snapshot}" var = "result"> SELECT * from Employees; </sql:query> <table border = "1" width = "100%"> <tr> <th>Emp ID</th> <th>First Name</th> <th>Last Name</th> <th>Age</th> </tr> <c:forEach var = "row" items = "${result.rows}">
            <tr>
               <td><c:out value = "${row.id}"/></td> <td><c:out value = "${row.first}"/></td>
               <td><c:out value = "${row.last}"/></td> <td><c:out value = "${row.age}"/></td>
            </tr>
         </c:forEach>
      </table>
 
   </body>
</html>

Accédez au JSP ci-dessus, le résultat suivant sera affiché -

Emp ID First Name Last Name Age
100 Zara Ali 18
101 Mahnaz Fatma 25
102 Zaid Ali 30

Lorsque vous envoyez les données XML via HTTP, il est judicieux d'utiliser JSP pour gérer les documents XML entrants et sortants; par exemple, les documents RSS. Comme un document XML n'est qu'un tas de texte, en créer un via un JSP est beaucoup plus facile que créer un document HTML.

Envoi de XML depuis une JSP

Vous pouvez envoyer le contenu XML à l'aide de JSP de la même manière que vous envoyez du HTML. La seule différence est que vous devez définir le type de contenu de votre page sur text / xml. Pour définir le type de contenu, utilisez le<%@page%> tag, comme ça -

<%@ page contentType = "text/xml" %>

L'exemple suivant montre comment envoyer du contenu XML au navigateur -

<%@ page contentType = "text/xml" %>

<books>
   <book>
      <name>Padam History</name>
      <author>ZARA</author>
      <price>100</price>
   </book>
</books>

Accédez au XML ci-dessus à l'aide de différents navigateurs pour voir la présentation de l'arborescence de documents du XML ci-dessus.

Traitement XML dans JSP

Avant de procéder au traitement XML à l'aide de JSP, vous devrez copier les deux bibliothèques associées XML et XPath suivantes dans votre <Tomcat Installation Directory>\lib -

  • XercesImpl.jar - Téléchargez-le depuis https://www.apache.org/dist/xerces/j/

  • xalan.jar - Téléchargez-le depuis https://xml.apache.org/xalan-j/index.html

Mettons le contenu suivant dans le fichier books.xml -

<books>
   <book>
      <name>Padam History</name>
      <author>ZARA</author>
      <price>100</price>
   </book>
   
   <book>
      <name>Great Mistry</name>
      <author>NUHA</author>
      <price>2000</price>
   </book>
</books>

Essayez ce qui suit main.jsp, en gardant dans le même répertoire -

<%@ taglib prefix = "c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix = "x" uri="http://java.sun.com/jsp/jstl/xml" %>
 
<html>
   <head>
      <title>JSTL x:parse Tags</title>
   </head>

   <body>
      <h3>Books Info:</h3>
      <c:import var = "bookInfo" url="http://localhost:8080/books.xml"/>
 
      <x:parse xml = "${bookInfo}" var = "output"/> <b>The title of the first book is</b>: <x:out select = "$output/books/book[1]/name" />
      <br>
      
      <b>The price of the second book</b>: 
      <x:out select = "$output/books/book[2]/price" />
   </body>
</html>

Accédez à la JSP ci-dessus en utilisant http://localhost:8080/main.jsp, le résultat suivant sera affiché -

Books Info:

The title of the first book is:Padam History The price of the second book: 2000

Formatage de XML avec JSP

Considérez la feuille de style XSLT suivante style.xsl -

<?xml version = "1.0"?>
<xsl:stylesheet xmlns:xsl = "http://www.w3.org/1999/XSL/Transform" 
   version = "1.0">
 
   <xsl:output method = "html" indent = "yes"/>
   <xsl:template match = "/">
      <html>
         <body>
            <xsl:apply-templates/>
         </body>
      </html>
   </xsl:template>
    
   <xsl:template match = "books">
      <table border = "1" width = "100%">
         <xsl:for-each select = "book">
            <tr>
               <td>
                  <i><xsl:value-of select = "name"/></i>
               </td>
               
               <td>
                  <xsl:value-of select = "author"/>
               </td>
               
               <td>
                  <xsl:value-of select = "price"/>
               </td>
            </tr>
         </xsl:for-each>
      </table>
   
   </xsl:template>
</xsl:stylesheet>

Considérons maintenant le fichier JSP suivant -

<%@ taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix = "x" uri = "http://java.sun.com/jsp/jstl/xml" %>
 
<html>
   <head>
      <title>JSTL x:transform Tags</title>
   </head>
   
   <body>
      <h3>Books Info:</h3>
      <c:set var = "xmltext">
         <books>
            <book>
               <name>Padam History</name>
               <author>ZARA</author>
               <price>100</price>
            </book>
            
            <book>
               <name>Great Mistry</name>
               <author>NUHA</author>
               <price>2000</price>
            </book>
         </books>
      </c:set>
 
      <c:import url = "http://localhost:8080/style.xsl" var = "xslt"/>
      <x:transform xml = "${xmltext}" xslt = "${xslt}"/>
   </body>
</html>

Le résultat suivant sera affiché -

Books Info:

Padam History ZARA 100
Great Mistry NUHA 2000

Pour en savoir plus sur le traitement XML à l'aide de JSTL, vous pouvez consulter la bibliothèque de balises standard JSP .

Un JavaBean est une classe Java spécialement construite, écrite en Java et codée selon les spécifications de l'API JavaBeans.

Voici les caractéristiques uniques qui distinguent un JavaBean des autres classes Java -

  • Il fournit un constructeur par défaut sans argument.

  • Il doit être sérialisable et ce qui peut implémenter le Serializable interface.

  • Il peut avoir un certain nombre de propriétés qui peuvent être lues ou écrites.

  • Il peut avoir un certain nombre de "getter" et "setter"méthodes pour les propriétés.

Propriétés JavaBeans

Une propriété JavaBean est un attribut nommé auquel l'utilisateur de l'objet peut accéder. L'attribut peut être de n'importe quel type de données Java, y compris les classes que vous définissez.

Une propriété JavaBean peut être read, write, read only, ou write only. Les propriétés JavaBean sont accessibles via deux méthodes dans la classe d'implémentation de JavaBean -

S.No. Méthode et description
1

avoirPropertyName()

Par exemple, si le nom de la propriété est firstName , le nom de votre méthode seraitgetFirstName()pour lire cette propriété. Cette méthode est appelée accesseur.

2

ensemblePropertyName()

Par exemple, si le nom de la propriété est firstName , le nom de votre méthode seraitsetFirstName()pour écrire cette propriété. Cette méthode est appelée mutateur.

Un attribut en lecture seule n'aura qu'un getPropertyName() méthode, et un attribut en écriture seule n'aura qu'un setPropertyName() méthode.

Exemple JavaBeans

Considérez une classe d'étudiants avec peu de propriétés -

package com.tutorialspoint;

public class StudentsBean implements java.io.Serializable {
   private String firstName = null;
   private String lastName = null;
   private int age = 0;

   public StudentsBean() {
   }
   public String getFirstName(){
      return firstName;
   }
   public String getLastName(){
      return lastName;
   }
   public int getAge(){
      return age;
   }
   public void setFirstName(String firstName){
      this.firstName = firstName;
   }
   public void setLastName(String lastName){
      this.lastName = lastName;
   }
   public void setAge(Integer age){
      this.age = age;
   }
}

Accéder aux JavaBeans

le useBeanaction déclare un JavaBean à utiliser dans une JSP. Une fois déclaré, le bean devient une variable de script accessible à la fois par les éléments de script et par d'autres balises personnalisées utilisées dans la JSP. La syntaxe complète de la balise useBean est la suivante -

<jsp:useBean id = "bean's name" scope = "bean's scope" typeSpec/>

Ici, les valeurs de l'attribut scope peuvent être page, request, session ou application basedsur votre condition. La valeur duid l'attribut peut être n'importe quelle valeur tant qu'il s'agit d'un nom unique parmi d'autres useBean declarations dans le même JSP.

L'exemple suivant montre comment utiliser l'action useBean -

<html>
   <head>
      <title>useBean Example</title>
   </head>
   
   <body>
      <jsp:useBean id = "date" class = "java.util.Date" /> 
      <p>The date/time is <%= date %>
   </body>
</html>

Vous recevrez le résultat suivant - -

The date/time is Thu Sep 30 11:18:11 GST 2010

Accès aux propriétés JavaBeans

De même que <jsp:useBean...> action, vous pouvez utiliser le <jsp:getProperty/> action pour accéder aux méthodes get et à la <jsp:setProperty/>action pour accéder aux méthodes définies. Voici la syntaxe complète -

<jsp:useBean id = "id" class = "bean's class" scope = "bean's scope">
   <jsp:setProperty name = "bean's id" property = "property name"  
      value = "value"/>
   <jsp:getProperty name = "bean's id" property = "property name"/>
   ...........
</jsp:useBean>

L'attribut name fait référence à l'id d'un JavaBean précédemment introduit dans la JSP par l'action useBean. L'attribut de propriété est le nom duget ou la set méthodes qui doivent être appelées.

L'exemple suivant montre comment accéder aux données en utilisant la syntaxe ci-dessus -

<html>
   <head>
      <title>get and set properties Example</title>
   </head>
   
   <body>
      <jsp:useBean id = "students" class = "com.tutorialspoint.StudentsBean"> 
         <jsp:setProperty name = "students" property = "firstName" value = "Zara"/>
         <jsp:setProperty name = "students" property = "lastName" value = "Ali"/>
         <jsp:setProperty name = "students" property = "age" value = "10"/>
      </jsp:useBean>

      <p>Student First Name: 
         <jsp:getProperty name = "students" property = "firstName"/>
      </p>
      
      <p>Student Last Name: 
         <jsp:getProperty name = "students" property = "lastName"/>
      </p>
      
      <p>Student Age: 
         <jsp:getProperty name = "students" property = "age"/>
      </p>

   </body>
</html>

Faisons le StudentsBean.classdisponible dans CLASSPATH. Accédez au JSP ci-dessus. le résultat suivant sera affiché -

Student First Name: Zara 

Student Last Name: Ali 

Student Age: 10

Dans ce chapitre, nous aborderons les balises personnalisées dans JSP. Une balise personnalisée est un élément de langage JSP défini par l'utilisateur. Lorsqu'une page JSP contenant une balise personnalisée est traduite en servlet, la balise est convertie en opérations sur un objet appelé gestionnaire de balises. Le conteneur Web appelle ensuite ces opérations lorsque le servlet de la page JSP est exécuté.

Les extensions de balises JSP vous permettent de créer de nouvelles balises que vous pouvez insérer directement dans une page JavaServer. La spécification JSP 2.0 a introduit les gestionnaires de balises simples pour écrire ces balises personnalisées.

Pour écrire une balise personnalisée, vous pouvez simplement étendre SimpleTagSupport classe et remplacer le doTag() , où vous pouvez placer votre code pour générer du contenu pour la balise.

Créer une balise "Hello"

Considérez que vous souhaitez définir une balise personnalisée nommée <ex: Hello> et que vous souhaitez l'utiliser de la manière suivante sans corps -

<ex:Hello />

Pour créer une balise JSP personnalisée, vous devez d'abord créer une classe Java qui agit comme un gestionnaire de balises. Créons maintenant leHelloTag classe comme suit -

package com.tutorialspoint;

import javax.servlet.jsp.tagext.*;
import javax.servlet.jsp.*;
import java.io.*;

public class HelloTag extends SimpleTagSupport {
   public void doTag() throws JspException, IOException {
      JspWriter out = getJspContext().getOut();
      out.println("Hello Custom Tag!");
   }
}

Le code ci-dessus a un codage simple où le doTag() prend l'objet JspContext actuel à l'aide de la getJspContext() méthode et l'utilise pour envoyer "Hello Custom Tag!" au courant JspWriter objet

Compilons la classe ci-dessus et copions-la dans un répertoire disponible dans la variable d'environnement CLASSPATH. Enfin, créez le fichier de bibliothèque de balises suivant:<Tomcat-Installation-Directory>webapps\ROOT\WEB-INF\custom.tld.

<taglib>
   <tlib-version>1.0</tlib-version>
   <jsp-version>2.0</jsp-version>
   <short-name>Example TLD</short-name>
   
   <tag>
      <name>Hello</name>
      <tag-class>com.tutorialspoint.HelloTag</tag-class>
      <body-content>empty</body-content>
   </tag>
</taglib>

Utilisons maintenant la balise personnalisée définie ci-dessus Hello dans notre programme JSP comme suit -

<%@ taglib prefix = "ex" uri = "WEB-INF/custom.tld"%>

<html>
   <head>
      <title>A sample custom tag</title>
   </head>
   
   <body>
      <ex:Hello/>
   </body>
</html>

Appelez le JSP ci-dessus et cela devrait produire le résultat suivant -

Hello Custom Tag!

Accéder au corps de l'étiquette

Vous pouvez inclure un message dans le corps de la balise comme vous l'avez vu avec les balises standard. Considérez que vous souhaitez définir une balise personnalisée nommée<ex:Hello> et vous voulez l'utiliser de la manière suivante avec un corps -

<ex:Hello>
   This is message body
</ex:Hello>

Faisons les changements suivants dans le code de la balise ci-dessus pour traiter le corps de la balise -

package com.tutorialspoint;

import javax.servlet.jsp.tagext.*;
import javax.servlet.jsp.*;
import java.io.*;

public class HelloTag extends SimpleTagSupport {
   StringWriter sw = new StringWriter();
   public void doTag()
   
   throws JspException, IOException {
      getJspBody().invoke(sw);
      getJspContext().getOut().println(sw.toString());
   }
}

Ici, la sortie résultant de l'appel est d'abord capturée dans un StringWriteravant d'être écrit dans le JspWriter associé à la balise. Nous devons changer le fichier TLD comme suit -

<taglib>
   <tlib-version>1.0</tlib-version>
   <jsp-version>2.0</jsp-version>
   <short-name>Example TLD with Body</short-name>
   
   <tag>
      <name>Hello</name>
      <tag-class>com.tutorialspoint.HelloTag</tag-class>
      <body-content>scriptless</body-content>
   </tag>
</taglib>

Appelons maintenant la balise ci-dessus avec le corps approprié comme suit -

<%@ taglib prefix = "ex" uri = "WEB-INF/custom.tld"%>

<html>
   <head>
      <title>A sample custom tag</title>
   </head>
   
   <body>
      <ex:Hello>
         This is message body
      </ex:Hello>
   </body>
</html>

Vous recevrez le résultat suivant -

This is message body

Attributs de balise personnalisés

Vous pouvez utiliser divers attributs avec vos balises personnalisées. Pour accepter une valeur d'attribut, une classe de balise personnalisée doit implémenter lesetter méthodes, identiques aux méthodes de définition JavaBean comme indiqué ci-dessous -

package com.tutorialspoint;

import javax.servlet.jsp.tagext.*;
import javax.servlet.jsp.*;
import java.io.*;

public class HelloTag extends SimpleTagSupport {
   private String message;

   public void setMessage(String msg) {
      this.message = msg;
   }
   StringWriter sw = new StringWriter();
   public void doTag()
   
   throws JspException, IOException {
      if (message != null) {
         /* Use message from attribute */
         JspWriter out = getJspContext().getOut();
         out.println( message );
      } else {
         /* use message from the body */
         getJspBody().invoke(sw);
         getJspContext().getOut().println(sw.toString());
      }
   }
}

Le nom de l'attribut est "message", donc la méthode setter est setMessage(). Ajoutons maintenant cet attribut dans le fichier TLD en utilisant le<attribute> élément comme suit -

<taglib>
   <tlib-version>1.0</tlib-version>
   <jsp-version>2.0</jsp-version>
   <short-name>Example TLD with Body</short-name>
   
   <tag>
      <name>Hello</name>
      <tag-class>com.tutorialspoint.HelloTag</tag-class>
      <body-content>scriptless</body-content>
      
      <attribute>
         <name>message</name>
      </attribute>
   
   </tag>
</taglib>

Suivons JSP avec l'attribut message comme suit -

<%@ taglib prefix = "ex" uri = "WEB-INF/custom.tld"%>

<html>
   <head>
      <title>A sample custom tag</title>
   </head>
   
   <body>
      <ex:Hello message = "This is custom tag" />
   </body>
</html>

Cela produira le résultat suivant -

This is custom tag

Pensez à inclure les propriétés suivantes pour un attribut -

S.No. Propriété et objectif
1

name

L'élément name définit le nom d'un attribut. Chaque nom d'attribut doit être unique pour une balise particulière.

2

required

Ceci spécifie si cet attribut est obligatoire ou facultatif. Ce serait faux pour facultatif.

3

rtexprvalue

Déclare si une valeur d'expression d'exécution pour un attribut de balise est valide

4

type

Définit le type de classe Java de cet attribut. Par défaut, il est supposé commeString

5

description

Une description informative peut être fournie.

6

fragment

Déclare si cette valeur d'attribut doit être traitée comme un JspFragment.

Voici l'exemple pour spécifier les propriétés liées à un attribut -

.....
   <attribute>
      <name>attribute_name</name>
      <required>false</required>
      <type>java.util.Date</type>
      <fragment>false</fragment>
   </attribute>
.....

Si vous utilisez deux attributs, vous pouvez modifier votre TLD comme suit -

.....
   <attribute>
      <name>attribute_name1</name>
      <required>false</required>
      <type>java.util.Boolean</type>
      <fragment>false</fragment>
   </attribute>
   
   <attribute>
      <name>attribute_name2</name>
      <required>true</required>
      <type>java.util.Date</type>
   </attribute>
.....

JSP Expression Language (EL) permet d'accéder facilement aux données d'application stockées dans les composants JavaBeans. JSP EL vous permet de créer des expressions à la fois(a) arithmétique et (b)logique. Dans une expression JSP EL, vous pouvez utiliserintegers, floating point numbers, strings, the built-in constants true and false pour les valeurs booléennes et null.

Syntaxe simple

En règle générale, lorsque vous spécifiez une valeur d'attribut dans une balise JSP, vous utilisez simplement une chaîne. Par exemple -

<jsp:setProperty name = "box" property = "perimeter" value = "100"/>

JSP EL vous permet de spécifier une expression pour l'une de ces valeurs d'attribut. Une syntaxe simple pour JSP EL est la suivante -

${expr}

Ici exprspécifie l'expression elle-même. Les opérateurs les plus courants dans JSP EL sont. et []. Ces deux opérateurs vous permettent d'accéder à divers attributs des Java Beans et des objets JSP intégrés.

Par exemple, la syntaxe ci-dessus <jsp:setProperty> tag peut être écrit avec une expression comme -

<jsp:setProperty name = "box" property = "perimeter" 
   value = "${2*box.width+2*box.height}"/>

Lorsque le compilateur JSP voit le ${} forme dans un attribut, il génère du code pour évaluer l'expression et remplace la valeur de expresson.

Vous pouvez également utiliser les expressions JSP EL dans le texte du modèle pour une balise. Par exemple, le<jsp:text>La balise insère simplement son contenu dans le corps d'une JSP. Le suivant<jsp:text> insertions de déclaration <h1>Hello JSP!</h1> dans la sortie JSP -

<jsp:text>
   <h1>Hello JSP!</h1>
</jsp:text>

Vous pouvez désormais inclure une expression JSP EL dans le corps d'un <jsp:text> tag (ou tout autre tag) avec le même ${}syntaxe que vous utilisez pour les attributs. Par exemple -

<jsp:text>
   Box Perimeter is: ${2*box.width + 2*box.height}
</jsp:text>

Les expressions EL peuvent utiliser des parenthèses pour regrouper les sous-expressions. Par exemple,${(1 + 2) * 3} equals 9, but ${1 + (2 * 3)} equals 7.

Pour désactiver l'évaluation des expressions EL, nous spécifions le isELIgnored attribut de la directive de page comme ci-dessous -

<%@ page isELIgnored = "true|false" %>

Les valeurs valides de cet attribut sont true et false. Si c'est vrai, les expressions EL sont ignorées lorsqu'elles apparaissent dans le texte statique ou les attributs de balise. S'il est faux, les expressions EL sont évaluées par le conteneur.

Opérateurs de base en EL

JSP Expression Language (EL) prend en charge la plupart des opérateurs arithmétiques et logiques pris en charge par Java. Le tableau suivant répertorie les opérateurs les plus fréquemment utilisés -

S.No. Opérateur et description
1

.

Accéder à une propriété de bean ou à une entrée de carte

2

[]

Accéder à un tableau ou à un élément de liste

3

( )

Regrouper une sous-expression pour modifier l'ordre d'évaluation

4

+

Une addition

5

-

Soustraction ou négation d'une valeur

6

*

Multiplication

sept

/ or div

Division

8

% or mod

Modulo (reste)

9

== or eq

Test d'égalité

dix

!= or ne

Test d'inégalité

11

< or lt

Tester moins de

12

> or gt

Tester plus de

13

<= or le

Tester pour inférieur ou égal

14

>= or ge

Test pour supérieur ou égal

15

&& or and

Test du ET logique

16

|| or or

Test du OU logique

17

! or not

Complément booléen unaire

18

empty

Tester les valeurs de variable vides

Fonctions dans JSP EL

JSP EL vous permet également d'utiliser des fonctions dans des expressions. Ces fonctions doivent être définies dans les bibliothèques de balises personnalisées. Une utilisation de fonction a la syntaxe suivante -

${ns:func(param1, param2, ...)}

ns est l'espace de noms de la fonction, func est le nom de la fonction et param1est la première valeur de paramètre. Par exemple, la fonctionfn:length, qui fait partie de la bibliothèque JSTL. Cette fonction peut être utilisée comme suit pour obtenir la longueur d'une chaîne.

${fn:length("Get my length")}

Pour utiliser une fonction de n'importe quelle bibliothèque de balises (standard ou personnalisée), vous devez installer cette bibliothèque sur votre serveur et inclure la bibliothèque dans votre JSP en utilisant le <taglib> directive comme expliqué dans le chapitre JSTL.

Objets implicites JSP EL

Le langage d'expression JSP prend en charge les objets implicites suivants -

S. Non Objet implicite et description
1

pageScope

Variables de portée de la portée de la page

2

requestScope

Variables de portée de la portée de la demande

3

sessionScope

Variables de portée de la portée de session

4

applicationScope

Variables de portée de la portée de l'application

5

param

Demander des paramètres sous forme de chaînes

6

paramValues

Demander des paramètres sous forme de collections de chaînes

sept

header

En-têtes de requête HTTP sous forme de chaînes

8

headerValues

En-têtes de requête HTTP en tant que collections de chaînes

9

initParam

Paramètres d'initialisation du contexte

dix

cookie

Valeurs des cookies

11

pageContext

L'objet JSP PageContext pour la page actuelle

Vous pouvez utiliser ces objets dans une expression comme s'il s'agissait de variables. Les exemples qui suivent vous aideront à comprendre les concepts -

L'objet pageContext

L'objet pageContext vous donne accès à l'objet JSP pageContext. Grâce à l'objet pageContext, vous pouvez accéder à l'objet de requête. Par exemple, pour accéder à la chaîne de requête entrante pour une requête, vous pouvez utiliser l'expression suivante -

${pageContext.request.queryString}

Les objets Scope

le pageScope, requestScope, sessionScope, et applicationScope les variables permettent d'accéder aux variables stockées à chaque niveau de portée.

Par exemple, si vous avez besoin d'accéder explicitement à la variable box dans la portée de l'application, vous pouvez y accéder via la variable applicationScope comme applicationScope.box.

Les objets param et paramValues

Les objets param et paramValues ​​vous donnent accès aux valeurs de paramètres normalement disponibles via le request.getParameter et request.getParameterValues méthodes.

Par exemple, pour accéder à un paramètre nommé order, utilisez l'expression ${param.order} ou ${param["order"]}.

Voici l'exemple pour accéder à un paramètre de requête nommé username -

<%@ page import = "java.io.*,java.util.*" %>
<%String title = "Accessing Request Param";%>

<html>
   <head>
      <title><% out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><% out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>${param["username"]}</p>
      </div>
   </body>
</html>

L'objet param renvoie des valeurs de chaîne unique, tandis que l'objet paramValues ​​renvoie des tableaux de chaînes.

Objets header et headerValues

Les objets header et headerValues ​​vous donnent accès aux valeurs d'en-tête normalement disponibles via le request.getHeader et le request.getHeaders méthodes.

Par exemple, pour accéder à un en-tête nommé user-agent, utilisez l'expression ${header.user-agent} ou ${header["user-agent"]}.

Voici l'exemple pour accéder à un paramètre d'en-tête nommé user-agent -

<%@ page import = "java.io.*,java.util.*" %>
<%String title = "User Agent Example";%>

<html>
   <head>
      <title><% out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><% out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>${header["user-agent"]}</p>
      </div>
   </body>
</html>

La sortie sera un peu comme ce qui suit -

User Agent Example

Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; HPNTDF; .NET4.0C; InfoPath.2)

L'objet d'en-tête renvoie des valeurs de chaîne unique, tandis que l'objet headerValues ​​renvoie des tableaux de chaînes.

Dans ce chapitre. nous discuterons 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 à propos d'une 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 la suivante -

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 les 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 main.jsp, il devrait générer une sortie un peu comme celle-ci -

An exception occurred: / by zero

Dans ce chapitre, nous aborderons le débogage d'une JSP. Il est toujours difficile de tester / déboguer une JSP et des servlets. JSP et servlets ont tendance à impliquer une grande quantité d'interaction client / serveur, ce qui rend les erreurs probables mais difficiles à reproduire.

Voici quelques conseils et suggestions qui peuvent vous aider dans votre débogage.

Utilisation de System.out.println ()

System.out.println()est facile à utiliser comme marqueur pour tester si un certain morceau de code est en cours d'exécution ou non. Nous pouvons également imprimer les valeurs des variables. Considérez les points supplémentaires suivants -

  • Étant donné que l'objet System fait partie des objets Java de base, il peut être utilisé partout sans avoir besoin d'installer de classes supplémentaires. Ceci comprendServlets, JSP, RMI, EJB's, ordinary Beans et classes, et standalone applications.

  • Par rapport à l'arrêt aux points d'arrêt, l'écriture dans System.out n'interfère pas beaucoup avec le flux d'exécution normal de l'application, ce qui la rend très utile lorsque l'iming est cruciale.

Voici la syntaxe à utiliser System.out.println() -

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

L'exemple suivant montre comment utiliser 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>

Accédez à la JSP ci-dessus, le navigateur affichera le résultat suivant -

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

Si vous utilisez Tomcat, vous trouverez également ces lignes ajoutées à la fin de stdout.log dans le répertoire des journaux.

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

De cette façon, vous pouvez importer des variables et d'autres informations dans le journal système qui peuvent être analysées pour découvrir la cause profonde du problème ou pour diverses autres raisons.

Utilisation de l'enregistreur JDB

le J2SELe framework de journalisation est conçu pour fournir des services de journalisation pour toute classe exécutée dans la JVM. Nous pouvons utiliser ce cadre pour enregistrer toute information.

Réécrivons l'exemple ci-dessus en utilisant l'API JDK logger -

<%@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>

Le code ci-dessus générera un résultat similaire sur le navigateur et dans stdout.log, mais vous aurez des informations supplémentaires dans stdout.log. Nous utiliserons leinfométhode de l'enregistreur car et enregistrez le message uniquement à des fins d'information. Voici un aperçu du fichier 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

Les messages peuvent être envoyés à différents niveaux en utilisant les fonctions pratiques severe(), warning(), info(), config(), fine(), finer(), et finest(). Ici, la méthode finest () peut être utilisée pour enregistrer les informations les plus fines et la méthode severest () peut être utilisée pour enregistrer les informations graves.

Vous pouvez utiliser Log4J Framework pour consigner les messages dans différents fichiers en fonction de leurs niveaux de gravité et de leur importance.

Outils de débogage

NetBeans est un environnement de développement intégré Java gratuit et open-source qui prend en charge le développement d'applications Java autonomes et d'applications Web prenant en charge les spécifications JSP et servlet et comprend également un débogueur JSP.

NetBeans prend en charge les fonctionnalités de débogage de base suivantes -

  • Breakpoints
  • Parcourir le code
  • Watchpoints

Vous pouvez vous référer à NetBeans documentation pour comprendre les fonctionnalités de débogage ci-dessus.

Utilisation du débogueur JDB

Vous pouvez déboguer JSP et servlets avec le même jdb commandes que vous utilisez pour déboguer une applet ou une application.

Pour déboguer une JSP ou un servlet, vous pouvez déboguer sun.servlet.http.HttpServer, puis observez que HttpServer exécute les JSP / servlets en réponse aux requêtes HTTP que nous faisons à partir d'un navigateur. Ceci est très similaire à la façon dont les applets sont débogués. La différence est qu'avec les applets, le programme en cours de débogage estsun.applet.AppletViewer.

La plupart des débogueurs cachent ce détail en sachant automatiquement comment déboguer les applets. Jusqu'à ce qu'ils fassent de même pour JSP, vous devez aider votre débogueur en tenant compte de ce qui suit -

  • Définissez le chemin de classe de votre débogueur. Cela vous aide à trouversun.servlet.http.Http-Server et les classes associées.

  • Définissez le chemin de classe de votre débogueur. Cela vous aide à trouver votre JSP et les classes de support, généralementROOT\WEB-INF\classes.

Une fois que vous avez défini le chemin de classe approprié, démarrez le débogage sun.servlet.http.HttpServer. Vous pouvez définir des points d'arrêt dans la JSP que vous souhaitez déboguer, puis utiliser un navigateur Web pour faire une requête au HttpServer pour la JSP donnée(http://localhost:8080/JSPToDebug). L'exécution s'arrête ici aux points d'arrêt.

Utilisation des commentaires

Les commentaires dans votre code peuvent aider le processus de débogage de différentes manières. Les commentaires peuvent être utilisés de nombreuses autres manières dans le processus de débogage.

Le JSP utilise des commentaires Java et single line (// ...) et multiple line (/* ... */)Les commentaires peuvent être utilisés pour supprimer temporairement des parties de votre code Java. Si le bogue disparaît, examinez de plus près le code que vous venez de commenter et découvrez le problème.

En-têtes client et serveur

Parfois, lorsqu'une JSP ne se comporte pas comme prévu, il est utile de regarder la requête et la réponse HTTP brutes. Si vous connaissez la structure de HTTP, vous pouvez lire la requête et la réponse et voir ce qui se passe exactement avec ces en-têtes.

Conseils de débogage importants

Voici une liste de quelques autres conseils de débogage sur le débogage JSP -

  • Demandez à un navigateur d'afficher le contenu brut de la page qu'il affiche. Cela peut aider à identifier les problèmes de formatage. C'est généralement une option dans le menu Affichage.

  • Assurez-vous que le navigateur ne met pas en cache la sortie d'une requête précédente en forçant un rechargement complet de la page. AvecNetscape Navigator, utilisation Shift-Reload; avecInternet Explorer utilisation Shift-Refresh.

Les pages et servlets JavaServer mettent à la disposition des développeurs Web plusieurs mécanismes pour sécuriser les applications. Les ressources sont protégées de manière déclarative en les identifiant dans le descripteur de déploiement d'application et en leur attribuant un rôle.

Plusieurs niveaux d'authentification sont disponibles, allant de l'authentification de base à l'aide d'identifiants et de mots de passe à l'authentification sophistiquée à l'aide de certificats.

Authentification basée sur les rôles

Le mécanisme d'authentification dans la spécification de servlet utilise une technique appelée role-based security. L'idée est qu'au lieu de restreindre les ressources au niveau de l'utilisateur, vous créez des rôles et limitez les ressources par rôle.

Vous pouvez définir différents rôles dans le fichier tomcat-users.xml, qui se trouve dans le répertoire personnel de Tomcat dans conf. Un exemple de ce fichier est présenté ci-dessous -

<?xml version = '1.0' encoding = 'utf-8'?>
<tomcat-users>
   <role rolename = "tomcat"/>
   <role rolename = "role1"/>
   <role rolename = "manager"/>
   <role rolename = "admin"/>
   <user username = "tomcat" password = "tomcat" roles = "tomcat"/>
   <user username = "role1" password = "tomcat" roles = "role1"/>
   <user username = "both" password = "tomcat" roles = "tomcat,role1"/>
   <user username = "admin" password = "secret" roles = "admin,manager"/>
</tomcat-users>

Ce fichier définit un mappage simple entre username, password, et role. Notez qu'un utilisateur donné peut avoir plusieurs rôles; par exemple,username = "both" est dans le rôle "tomcat" et le rôle "role1".

Une fois que vous avez identifié et défini différents rôles, des restrictions de sécurité basées sur les rôles peuvent être placées sur différentes ressources d'application Web à l'aide de la <security-constraint> élément dans web.xml fichier disponible dans le répertoire WEB-INF.

Voici un exemple d'entrée dans web.xml -

<web-app>
   ...
   <security-constraint>
      <web-resource-collection>
         <web-resource-name>SecuredBookSite</web-resource-name>
         <url-pattern>/secured/*</url-pattern>
         <http-method>GET</http-method>
         <http-method>POST</http-method>
      </web-resource-collection>
      
      <auth-constraint>
         <description>
            Let only managers use this app
         </description>
         <role-name>manager</role-name>
      </auth-constraint>
   </security-constraint>
   
   <security-role>
      <role-name>manager</role-name>
   </security-role>
   
   <login-config>
      <auth-method>BASIC</auth-method>
   </login-config>
   ...
</web-app>

Les entrées ci-dessus signifieraient -

  • Toute requête HTTP GET ou POST adressée à une URL correspondant à / secure / * serait soumise à la restriction de sécurité.

  • Une personne ayant le rôle de gestionnaire a accès aux ressources sécurisées.

  • le login-config élément est utilisé pour décrire le BASIC forme d'authentification.

Si vous essayez de parcourir une URL, y compris /securityrépertoire, la boîte de dialogue suivante s'affiche pour vous demander le nom d'utilisateur et le mot de passe. Si vous fournissez un utilisateur"admin" et mot de passe "secret", vous aurez alors accès à l'URL correspondant à /secured/* car nous avons défini l'utilisateur admin avec le rôle de gestionnaire qui est autorisé à accéder à cette ressource.

Authentification par formulaire

Lorsque vous utilisez la méthode d'authentification FORM, vous devez fournir un formulaire de connexion pour inviter l'utilisateur à entrer un nom d'utilisateur et un mot de passe. Voici un simple code delogin.jsp. Cela permet de créer un formulaire dans le même but -

<html>
   <body bgcolor = "#ffffff">
      
      <form method = "POST" action ="j_security_check">
         <table border = "0">
            <tr>
               <td>Login</td>
               <td><input type = "text" name="j_username"></td>
            </tr>
            <tr>
               <td>Password</td>
               <td><input type = "password" name="j_password"></td>
            </tr>
         </table>
         <input type = "submit" value = "Login!">
      </form>
      
   </body>
</html>

Ici, vous devez vous assurer que le formulaire de connexion doit contenir les éléments du formulaire nommés j_username et j_password. L'action dans le<form> la balise doit être j_security_check. POSTdoit être utilisé comme méthode de formulaire. Dans le même temps, vous devrez modifier le<login-config> balise pour spécifier la méthode d'authentification comme FORM -

<web-app>
   ...
   <security-constraint>
      <web-resource-collection>
         <web-resource-name>SecuredBookSite</web-resource-name>
         <url-pattern>/secured/*</url-pattern>
            <http-method>GET</http-method>
            <http-method>POST</http-method>
      </web-resource-collection>
      
      <auth-constraint>
         <description>Let only managers use this app</description>
         <role-name>manager</role-name>
      </auth-constraint>
   </security-constraint>
   
   <security-role>
      <role-name>manager</role-name>
   </security-role>
   
   <login-config>
      <auth-method>FORM</auth-method>
      <form-login-config>
         <form-login-page>/login.jsp</form-login-page>
         <form-error-page>/error.jsp</form-error-page>
      </form-login-config>
   </login-config>
   ...
</web-app>

Maintenant, lorsque vous essayez d'accéder à n'importe quelle ressource avec URL /secured/*, il affichera le formulaire ci-dessus demandant l'identifiant et le mot de passe. Lorsque le conteneur voit le "j_security_check", il utilise un mécanisme interne pour authentifier l'appelant.

Si la connexion réussit et que l'appelant est autorisé à accéder à la ressource sécurisée, le conteneur utilise un identifiant de session pour identifier une session de connexion pour l'appelant à partir de ce point. Le conteneur maintient la session de connexion avec un cookie contenant l'identifiant de session. Le serveur renvoie le cookie au client et tant que l'appelant présente ce cookie avec les demandes suivantes, le conteneur saura qui est l'appelant.

Si la connexion échoue, le serveur renvoie la page identifiée par le paramètre form-error-page

Ici, j_security_checkest l'action que les applications utilisant une connexion basée sur un formulaire doivent spécifier pour le formulaire de connexion. Dans le même formulaire, vous devriez également avoir un contrôle de saisie de texte appeléj_username et un password input control appelé j_password. Lorsque vous voyez cela, cela signifie que les informations contenues dans le formulaire seront soumises au serveur, qui vérifiera le nom et le mot de passe. La manière de procéder est spécifique au serveur.

Vérifiez les implémentations de royaume standard pour comprendre commentj_security_check fonctionne pour le conteneur Tomcat.

Sécurité programmatique dans un servlet / JSP

le HttpServletRequest object fournit les méthodes suivantes, qui peuvent être utilisées pour extraire les informations de sécurité au moment de l'exécution -

S.No. Méthode et description
1

String getAuthType()

le getAuthType() La méthode renvoie un objet String qui représente le nom du schéma d'authentification utilisé pour protéger le servlet.

2

boolean isUserInRole(java.lang.String role)

le isUserInRole() La méthode renvoie une valeur booléenne: true si l'utilisateur est dans le rôle donné ou false dans le cas contraire.

3

String getProtocol()

le getProtocol()La méthode retourne un objet String représentant le protocole utilisé pour envoyer la demande. Cette valeur peut être vérifiée pour déterminer si un protocole sécurisé a été utilisé.

4

boolean isSecure()

le isSecure()La méthode renvoie une valeur booléenne indiquant si la demande a été effectuée à l'aide de HTTPS. La valeur true signifie que c'était le cas et que la connexion est sécurisée. La valeur false signifie que la demande ne l'était pas.

5

Principle getUserPrinciple()

le getUserPrinciple() renvoie un objet java.security.Principle qui contient le nom de l'utilisateur authentifié actuel.

Par exemple, pour une page JavaServer qui renvoie vers des pages pour les gestionnaires, vous pouvez avoir le code suivant -

<% if (request.isUserInRole("manager")) { %>
   <a href = "managers/mgrreport.jsp">Manager Report</a>
   <a href = "managers/personnel.jsp">Personnel Records</a>
<% } %>

En vérifiant le rôle de l'utilisateur dans une JSP ou un servlet, vous pouvez personnaliser la page Web pour afficher à l'utilisateur uniquement les éléments auxquels il peut accéder. Si vous avez besoin du nom de l'utilisateur tel qu'il a été saisi dans le formulaire d'authentification, vous pouvez appeler legetRemoteUser méthode dans l'objet de requête.

Dans ce chapitre, nous discuterons du concept d'internationalisation dans JSP. Avant de continuer, comprenons les trois termes importants suivants -

  • Internationalization (i18n) - Cela signifie permettre à un site Web de fournir différentes versions de contenu traduites dans la langue ou la nationalité du visiteur.

  • Localization (l10n) - Cela signifie ajouter des ressources à un site Web pour l'adapter à une région géographique ou culturelle particulière, par exemple la traduction en hindi sur un site Web.

  • locale- Il s'agit d'une région culturelle ou géographique particulière. Il est généralement appelé un symbole de langue suivi d'un symbole de pays séparé par un trait de soulignement. Par exemple, "en_US"représente la langue anglaise pour les États-Unis.

Il y a un certain nombre d'éléments qui doivent être pris en compte lors de la création d'un site Web mondial. Ce didacticiel ne vous donnera pas tous les détails à ce sujet, mais il vous donnera un bon exemple sur la façon dont vous pouvez offrir votre page Web dans différentes langues à la communauté Internet en différenciant leur emplacement, c'est-à-dire les paramètres régionaux.

Un JSP peut choisir la version appropriée du site en fonction des paramètres régionaux du demandeur et fournir une version de site appropriée en fonction de la langue, de la culture et des exigences locales. Voici la méthode d'objet de requête qui renvoie l'objet Locale.

java.util.Locale request.getLocale()

Détection des paramètres régionaux

Voici les méthodes locales importantes que vous pouvez utiliser pour détecter requester's location, language et bien sûr locale. Toutes les méthodes ci-dessous affichent le nom du pays et le nom de la langue définis dans le navigateur du demandeur.

S.No. Méthode et description
1

String getCountry()

Cette méthode renvoie le code du pays / région en majuscules pour ce paramètre régional au format ISO 3166 à 2 lettres.

2

String getDisplayCountry()

Cette méthode renvoie un nom pour le pays des paramètres régionaux approprié pour l'affichage à l'utilisateur.

3

String getLanguage()

Cette méthode renvoie le code de langue en minuscules pour cette locale au format ISO 639.

4

String getDisplayLanguage()

Cette méthode retourne un nom pour la langue des paramètres régionaux appropriée pour l'affichage à l'utilisateur.

5

String getISO3Country()

Cette méthode renvoie une abréviation de trois lettres pour le pays de cette locale.

6

String getISO3Language()

Cette méthode renvoie une abréviation de trois lettres pour la langue de cette locale.

Exemple

L'exemple suivant montre comment afficher une langue et un pays associé pour une requête dans une JSP -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>
<%
   //Get the client's Locale
   Locale locale = request.getLocale();
   String language = locale.getLanguage();
   String country = locale.getCountry();
%>

<html>
   <head>
      <title>Detecting Locale</title>
   </head>

   <body>
      <center>
         <h1>Detecting Locale</h1>
      </center>
      
      <p align = "center">
         <% 
            out.println("Language : " + language  + "<br />");
            out.println("Country  : " + country   + "<br />");
         %>
      </p>
   </body>
</html>

Réglage des langues

Un JSP peut produire une page écrite dans une langue d'Europe occidentale telle que l'anglais, l'espagnol, l'allemand, le français, l'italien, le néerlandais, etc. Ici, il est important de définir l'en-tête Content-Language pour afficher correctement tous les caractères.

Un autre point important est d'afficher tous les caractères spéciaux à l'aide d'entités HTML; par exemple,"&#241;" représente "ñ", et "&#161;" représente "¡" comme suit -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>

<%
   // Set response content type
   response.setContentType("text/html");
   
   // Set spanish language code.
   response.setHeader("Content-Language", "es");
   String title = "En Español";
%>

<html>
   <head>
      <title><%  out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><%  out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>En Español</p>
         <p>¡Hola Mundo!</p>
      </div>
   </body>
</html>

Dates spécifiques aux paramètres régionaux

Vous pouvez utiliser le java.text.DateFormat classe et son statique getDateTimeInstance( )méthode pour formater la date et l'heure spécifiques aux paramètres régionaux. Voici l'exemple qui montre comment formater des dates spécifiques à une locale donnée -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>
<%@ page import = "java.text.DateFormat,java.util.Date" %>

<%
   String title = "Locale Specific Dates";
   
   //Get the client's Locale
   Locale locale = request.getLocale( );
   
   String date = DateFormat.getDateTimeInstance(
      DateFormat.FULL, 
      DateFormat.SHORT, 
      locale).format(new Date( ));
%>

<html>
   
   <head>
      <title><% out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><% out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>Local Date: <%  out.print(date); %></p>
      </div>
   </body>
</html>

Monnaie spécifique aux paramètres régionaux

Vous pouvez utiliser le java.txt.NumberFormat classe et son statique getCurrencyInstance( )méthode pour formater un nombre, tel qu'un type long ou double, dans une devise spécifique à la locale. Voici l'exemple qui montre comment formater une devise spécifique à une locale donnée -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>
<%@ page import = "java.text.NumberFormat,java.util.Date" %>

<%
   String title = "Locale Specific Currency";
   
   //Get the client's Locale
   Locale locale = request.getLocale( );
   
   NumberFormat nft = NumberFormat.getCurrencyInstance(locale);
   String formattedCurr = nft.format(1000000);
%>

<html>
   
   <head>
      <title><% out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><% out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>Formatted Currency: <%  out.print(formattedCurr); %></p>
      </div>
   </body>
</html>

Pourcentage spécifique aux paramètres régionaux

Vous pouvez utiliser le java.txt.NumberFormat classe et son statique getPercentInstance( )méthode pour obtenir le pourcentage spécifique aux paramètres régionaux. L'exemple suivant montre comment formater le pourcentage spécifique à un paramètre régional donné -

<%@ page import = "java.io.*,java.util.Locale" %>
<%@ page import = "javax.servlet.*,javax.servlet.http.* "%>
<%@ page import = "java.text.NumberFormat,java.util.Date" %>

<%
   String title = "Locale Specific Percentage";
   
   //Get the client's Locale
   Locale locale = request.getLocale( );
   
   NumberFormat nft = NumberFormat.getPercentInstance(locale);
   String formattedPerc = nft.format(0.51);
%>

<html>
   
   <head>
      <title><% out.print(title); %></title>
   </head>
   
   <body>
      <center>
         <h1><% out.print(title); %></h1>
      </center>
      
      <div align = "center">
         <p>Formatted Percentage: <%  out.print(formattedPerc); %></p>
      </div>
   </body>
</html>