Programmation JEE/JSP
Java Server Pages ou JSP est une technologie basée sur Java permettant de créer des pages web dynamiques à l'aide du langage java en l'intégrant au contenu HTML de la page à l'aide de scriptlets. Le code source est ensuite pré-compilé en Java Applets, puis converti en fichier HTML par le serveur d'applications. Ainsi le code n'est pas diffusé et devient difficilement téléchargeable depuis un navigateur web à moins d'en avoir l'accès. De ce fait, les risques de piratage en sont réduits. On compare souvent cette technologie à PHP, mais son fonctionnement se rapproche bien plus d'ASP .NET car le code est compilé et non interprété.
Installation
modifierWindows et Ubuntu ne permettent pas de lire les fichiers .jsp par défaut. Il faut donc télécharger et installer un serveur d'application Java EE tel que :
et bien d'autres encore.
Pour Tomcat, une fois lancé (dans Windows : démarrer, exécuter..., services.msc, ou bien en commande DOS : net start "Tomcat7") il suffit de placer les fichiers .jsp dans le répertoire adéquat pour qu'ils soient interprétés par le serveur (par défaut sur Windows 7 dans C:\Program Files\Apache Software Foundation\Tomcat 7.0\webapps\examples\). L'URL pointant vers ce répertoire est http://localhost:8080/examples/.
Directives JSP
modifier@page
modifierDéfinit le code généré durant le traitement de la page JSP
<%@page contentType="text/html"
pageEncoding="UTF-8"
errorPage="erreur.jsp"
import="java.util.*"
%>
Attributs :
- language="language" : langage à utiliser dans la jsp
- extends="package.nomDeClasse" : nom de la classe dont la page JSP va hériter
- import="nomDePackage1, nomDePackage2..." : noms des packages importés dans le code
- session="booléen" : détermine si la session est accessible depuis la JSP
- buffer="taille" : détermine la taille du buffer utilisé par JspWriter de la JSP
- autoFlush="booléen" : indique si le contenu du buffer doit être envoyé automatiquement vers le client une fois plein
- isThreadSafe="booléen" : indique le modèle de thread utilisé pour le traitement de la requête HTTP concernant la page JSP
- errorPage="url relative" : ressource appelée quand une exception est déclenchée et qu'il n'y a pas de try{}catch{} dans la page
- isErrorPage="booléen" : indique si la page gère les exceptions
- contentType="type Mime" : indique le type de documents contenus dans la réponse HTTP généré par la JSP
- pageEncoding="type d'encodage" : détermine le type d'encodage des caractères de la réponse HTTP
@include
modifierPermet d'inclure une autre ressource dans la page JSP
<%@include file="./chunk.jsp" %>
@taglib
modifierPermet d'utiliser une bibliothèque de balises JSP en utilisant un espace de nom.
<%-- Défini l'espace de nom "fmt" pour utiliser une bibliothèque de balises --%>
<%@taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<%-- Par la suite on utilise l'espace de nom fmt pour les balises de la bibliothèque --%>
<fmt:setBundle basename="informatique.ressources" />
<fmt:message key="service" />
Scriptlets
modifierLes scriptlets permettent l'injection de scripts interprétables dans une pile HTML.
<%! %>
modifierDéclaration de variables ou de méthodes
<%!
double tva=1.21;
double calculTarif(double prix)
{
return prix*tva;
}
%>
<% %>
modifierInsertion d'instructions de code
<%
double tva=1.21;
out.println(Double.parseDouble(request.getParameter("prix"))*tva);
%>
<%= %>
modifierÉvaluation d'expression, le résultat est retourné en out.println()
<%=new Date().toLocalString() %>
<%-- --%>
modifierCommentaires
<%-- Ceci est un commentaire --%>
Contrairement à un commentaire HTML standard entre <!--
et -->
, les commentaires JSP entre <%--
et --%>
ne sont pas écrits dans la page HTML générée.
Exemple
modifier<%-- index.jsp --%>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"
errorPage="erreur.jsp"
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<%!
String[] langages = {"Java", "CLisp", "Scheme", "OCaml"};
%>
<%
// levée d'une ArrayIndexOutOfBoundsException
for (int i=0; i < 4; i++) {
out.println(langages[i]);
}
%>
</body>
</html>
Lorsqu'une erreur est levée par exemple en remplaçant le nombre d'itérations de 4 à 5, la directive page renvoie sur erreur.jsp
<%-- erreur.jsp --%>
<%@ page isErrorPage="true"%>
<html>
<body>
exception levée <b> <%= exception %> </b>
<hr>
<h3>trace de la pile</h3>
<pre>
<%
java.io.PrintWriter pw = new java.io.PrintWriter(out);
exception.printStackTrace(pw);
%>
</pre>
</body>
</html>
Objets implicites
modifierEnsemble de variables prédéfinies pour accéder directement à certains objets
request
modifierpermet d'avoir une référence à HttpServletRequest utilisé pour contacter la JSP
response
modifierpermet d'avoir une référence à HttpServletResponse qui transfert le résultat du traitement de la JSP au client
pageContext
modifierpermet d'avoir un accès à pageContext de la JSP.
session
modifierpermet d'avoir une référence à HttpSession associé au client.
application
modifierréférence ServletContext associé à l'application contenant la JSP.
out
modifierréférence le flux de sortie de JspWriter permettant d'écrire dans la réponse HTTP.
config
modifierpermet de référencer ServletConfig associé à la JSP.
exception
modifierest disponible seulement dans une page dédiée aux erreurs et permet de référencer Exception qui redirige sur cette page de gestion d'erreur.
Balises JSP
modifierjsp:useBean
modifierCrée une instance d'un objet javabean.
Attributs :
- id :
- scope :
- class :
- type :
- beanName :
Exemple :
<jsp:useBean>
id="leManager"
type="pack.Personne"
class="pack.Manager"
scope="request"
</jsp:useBean>
jsp:getProperty
modifierPrend la valeur d'une propriété d'un javabean.
Attributs :
- name :
- property :
Exemple :
<jsp:getProperty name="leManager" property="nom" />
jsp:setProperty
modifierAssigne une valeur à la propriété d'un javabean.
Attributs :
- name :
- property :
- value :
Exemple :
<jsp:useBean id="manager" scope="session" class="pack.Manager" type="pack.Manager" />
<jsp:setProperty name="manager" property="heureConnexion" value="<%=new Date().toLocaleString()%>" />
jsp:include
modifierInclut une ressource statique ou dynamique et possède la balise <jsp:param> permettant de transmettre des paramètres à la ressource par l'attribut name (nom du paramètre) et l'attribut value (valeur du paramètre).
Attributs :
- page :
- flush :
Exemple :
<jsp:include page="/NbColis">
<jsp:param name="code" value="<%=request.getParameter("codeClient") %>" />
</jsp:include>
jsp:forward
modifierForward une requête client.
Exemple :
<jsp:forward page="/servlet/login">
<jsp:param name="username" value="jsmith" />
</jsp:forward>
jsp:plugin
modifierGère l'insertion d'un applet dans une page JSP.
Attributs :
- type :
- code :
- codebase :
- archive :
- name :
- align :
- width :
- height :
- vspace / hspace :
- jreversion :
- nspluginurl :
- iepluginurl :
Exemple :
<jsp:plugin type=applet code="Molecule.class" codebase="/html">
<jsp:params>
<jsp:param name="molecule" value="molecules/benzene.mol" />
</jsp:params>
<jsp:fallback>
<p>Impossible de charger l'applet</p>
</jsp:fallback>
</jsp:plugin>
Syntaxe XML
modifierSyntaxe JSP | Syntaxe XML | Commentaires |
---|---|---|
<%@page %> | <jsp:directive.page></jsp:directive.page> | attributs identiques pour les deux versions |
<%@include %> | <jsp:directive.include></jsp:directive.include> | attributs identiques pour les deux versions |
<%@taglib %> | pas de correspondance | utiliser xmlns:XXX de la balise <jsp:root> |
<%! %> | <jsp:declaration></jsp:declaration> | // |
<% %> | <jsp:scriptlet></jsp:scriptlet> | // |
<%= %> | <jsp:expression></jsp:expression> | // |
<%-- --%> | pas de correspondance | // |