JSP - Langage d'expression (EL)

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 sous forme de 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 devez 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.