Transcript JSP.

Cours JSP JSP

Java Server Pages

1

Cours JSP

Introduction

 Afin d’implémenter les règles métiers, coté serveur dans une application Web, l’architecture Java propose trois solutions :    En pur JAVA (servlets); À l’intérieur de code HTML (pages JSP); Mixage des deux premiers solutions. 2

Servlets

Cours JSP 3

Exemple Servlets

} import java.io.*; import javax.servlet.*; import javax.servlet.http.*; public class ExempleServlet extends HttpServlet { public void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { // positionnement du type de contenu res.setContentType("text/html"); // écriture du contenu PrintWriter out = res.getWriter(); out.println(""); out.println(""); out.println("ExempleServlet"); out.println(""); out.println(""); out.println("

ExempleServlet

"); out.println(""); out.println(""); out.close(); } Cours JSP 4

Cours JSP

JSP

  Consiste à insérer dans le code HTML des instructions qui sont exécutées sur le serveur.

Lorsque la page est sollicitée par une requête, ces instructions peuvent produire de l’HTML mais aussi accéder à une base de données et effectuer des calculs.

5

Exemple JSP

<%! Int compteur =0; %> Bonjour.
<% compteur ++; if (compteur == 1) %> Vous etes le premier visiteur.

<% else %> Vous etes le <%=compteur %> eme visiteur.

Cours JSP 6

Cours JSP

Solution mixte

Les solutions moderne des applications Web, permettent de mêler les deux premières solutions (Servlets et JSP) 7

Eléments de JSP

Scriptlet ;

Déclaration de variable ;

Conditionnel

;

L’objet out

;

Déclaration de Tableau

;

Boucle for ;

Commentaire JSP

;

Traitement des formulaires ;

 Cours JSP Accès aux bases de données; 8

Cours JSP

scriptlet

 Afin d’indiquer au serveur que ce qui suit est du JSP, en utilise la balise <% ………. %> 9

Déclaration de variable

       La balise <%! ……%> Permet de déclarer une variable.

Exemple: <%! Int i; %> <%! Int i = 0;%> <%! Float f, g = 1.2, h; %> Remarque: l’identificateur d’une variable doit respecter les règles des variables dans JAVA Cours JSP 10

Conditionnel

      L’expression conditionnel s’effectue par: <% if (condition) { actions %> } Cours JSP 11

Cours JSP         <% if (condition) { actions } else { actions } %> 12

Exemple

<% int i = 0; %>

<% ++1; If (i==1) { out.println(‘’vous etes le premier ‘’); } Else { out.print (‘’visiteur numero ‘’); out.println(i); } %>

Cours JSP 13

L’objet

out

Out est un objet prédéfini dans les pages JSP qui dispose de deux méthodes :  Print : pour afficher sur la page une information  syntaxe : out.print(…..); Println : pour afficher sur la page une information avec un saut de ligne.

syntaxe : out.prinln(….); Cours JSP 14

Exemple

<%! Int i = 0;%> exemple objet out

exemple

<% i++; If (i==1) { out.println(‘’Vous etes le premier visiteur’’);} Else { out.println(‘’Visiteur numero ‘’ + i); } %>
date courante : <%=new java.util.date() %> Cours JSP 15

Déclaration de

Tableau

   Un tableau permet de gérer plusieurs valeur de même type.

La déclaration se fait dans JAVA.

Exemple:  <% double[] prix = {12.5, 14, 18}; int[] qtes = {50, 20, 30}; %> Cours JSP 16

Boucle

for

  La boucle for est constituée d’un en tête entre parenthèses et d’un corps.

Syntaxe : for (variable itérative; condition d’interaction; pas) { actions; } Cours JSP 17

Exemple boucle for et tableau

<% for (int i=0; i< prix.length; i++) { out.println(‘’’’); out.print(‘’); out.print(‘’); %>
Quantite Prix
’’); out.print(qtes[i]); out.print(’’); out.print(prix[i]); out.print(
Cours JSP 18

Cours JSP

Commentaire JSP

  Un commentaire JSP s’effectue par la balise Remarque : si le commentaire est dans le scriptlet c’est un commentaire JAVA.

19

Cours JSP

Traitement des formulaires

   Introduction; Méthodes GET et POST; Récupération de la valeur d’un paramètre; 20

Introduction

  L’intérêt des formulaires est de pouvoir introduire des données en vue d’être traitées par une logique métier.

L’utilisation de formulaire et fait en deux temps:   L’utilisateur remplit un formulaire et le soumet au serveur.

Le serveur extrait les informations fournies par l’utilisateur et les utilise pour construire la réponse.

Cours JSP 21

Method GET

  Si l’attribut method de la balise form est get, le navigateur met les valeurs des paramètres dans l’en-tête de la requête elle-même.

De plus, la requête contient en clair les valeurs des paramètres et est stockée telle quelle dans l’historique, ce qui est judicieux si l’un de ces paramètres est un mot de passe.

Cours JSP 22

Cours JSP

Method POST

  Si l’attribut method de la balise form est post, le navigateur met les valeurs des paramètres dans l’en-tête de la requête elle-même.

Avec post, les valeurs des paramètres ne sont pas affichées dans l’URL.

23

Cours JSP

Récupération de la valeur d’un paramètre.

  La récupération de la valeur d’un paramètre s’effectue à travers l’objet request.

Cet objet dispose d’une méthode getParameter qui cherche la valeur d’un paramètre d’un formulaire.

24

Exemple de

getParamater

<% String nomUtilisateur = request.getParameter(‘’nom’’); String MotDePasse = request.getParameter(‘’motDePasse’’); %> Cours JSP 25

Paramètres à valeurs multiples

  Un paramètre peut avoir une valeur multiple. Dans ce cas, il faut utiliser la méthode getParameterValues(). Cette méthode renvoie un tableau de chaînes de caractères.

Cours JSP 26

Exemple de paramètres à valeurs multiples

<% String[] sportsFavoris = request.getParameterValues(‘’sp’’); Out.println(‘’

    ’’); For (int i=0; i < sprortsFavoris.length ; i++) { out.println(‘’
  • ’’ + sportsFavoris[i] + ‘’
  • ’’);} Out.println(‘’
’’); %> Cours JSP 27

Noms des paramètres

 La méthode getParameterNames permet d’obtenir un tableau contenant les noms de tous les paramètres présents dans la requête.

Cours JSP 28

Conversion d’une chaîne

  La méthode getParameter renvoie une chaîne de caractères. Si le paramètre est une valeur numérique, il faut convertir la chaîne de caractères en nombre pour pouvoir l’utiliser.

Cela se fait par la méthode JAVA appropriée :       Byte.parseByte; Short.parseShort; Integer.parseInt; Long.parseLong; Float.parseFloat; Double.parseDouble.

Cours JSP 29

Cours JSP

Exemple

<% String nbLignesCh = request.getParameter(‘’nblignes’’); Int nbLignes = Integer.parseInt(nbLignesCh); %> 30

Accès aux bases de données

   Java fournit une architecture standard pour dialoguer avec les bases de données.

Affin d’assurer la compatibilité de Java avec un maximum de base de données, ses concepts ont adopté l’architecture classique de pilotes. L’application Java (ou page JSP) utilise les mêmes instructions JDBC pour s’adresser au pilote.

Cours JSP 31

Quand un programme (une page JSP) souhaite accéder à une base, il commence par demander le chargement du pilote en mémoire.

Pour cela, il faut que la page JSP trouve ce pilote.

Cours JSP 32

Conditions d’accès à une base de données.

   Installer le pilote pour que la page JSP puisse le trouver; Dans la page JSP, demander le chargement en mémoire du pilote; Dans la page JSP, utiliser le pilote pour établir la connexion, effectuer les requêtes souhaitées.

Cours JSP 33

Installation d’un pilote.

   Cette action n’est faite qu’une seul fois, au moment du déploiement.

Retrouver le pilote dans le dossier

shared de Tomcat; Copier le pilote sous forme archive

jar sans le décompacter, dans l’un des dossiers suivants: Cours JSP 34

Option 1 d’installation du pilote

 Le pilote peut être placer dans le dossier lib; $TOMCAT_HOME/shared/lib Redémarrer Tomcat, pour la prise en charge du pilote. Cours JSP 35

Option 2 d’installation du pilote

 Le pilote peut être placer dans le dossier $TOMCAT_HOME/common/lib Redémarrer Tomcat Ceci rend le pilote accessible par toutes les applications web ainsi que Tomcat lui-même.

Cours JSP 36

Option 3 d’installation du pilote

 Le pilote peut aussi être placer dans le dossier $TOMCAT_HOME/webapps/nom_applicati on/WEB-INFO/lib Redémarrer l’application web «nom_application » Cours JSP 37

Accès à partir d’une page JSP

L’utilisation d’une base de données à partir de d’une page JSP comporte les étapes suivantes: 1.

Avoir le droit d’accès à un serveur de base de données; 2.

3.

Disposer d’un pilote correspondant à la base; Charger le pilote en mémoire; 4.

5.

Ouvrir une connexion vers la base; Effectuer des requêtes et exploiter les résultats; 6.

Libérer les ressources, en particulier fermer la connexion.

Les deux premiers étapes ont déjà été réalisées.

Cours JSP 38

Chargement du pilote en mémoire

 Il exit plusieurs manier de charger un pilote à partir d’une page JSP dont voici une;  Class.forName(nom de la classe);  Exemple de chargement d’un pilote «mysql» par une page JSP: Class.forName(‘’com.mysql.jdbc.Driver’’) Cours JSP 39

Etablissement de la connexion

 La connexion vers une base de donnée se fait par: Java.sql.Connection cnx = Java.sql.DriverManager.getConnection

(urlDelaBase, login, motDePasse); Cours JSP 40

Préparation de la requête

  Une fois la connexion établie, on peut l’utiliser autant de fois qu’on le souhaite; Pour cela, on lui demande d’instancier une requête par : Java.sql.Statement req = cnx.createStatement(); Cours JSP 41

 1.

2.

Exécution d’un SELECT

L’exécution d’une requête SQL SELECT se décompose on deux partie à savoir: L’envoi de la requête; L’exploitation du résultat.

Cours JSP 42

Envoi de la requête

    Pour effectuer une reqête de consultation (select), on invoque la méthode executeQuery du Statement en lui passant la requête SQL à effectuer.

Le résultat de cette requête est un ensemble de ligne représenté en JAVA par une instance de java.sql.ResultSet.

Exemple: Java.sql.ResultSet rs = req.executeQuery(‘’SELECT * FROM Client’’); Cours JSP 43

Exploitation des résultats

  Un java.sql.Result est un moyen de parcourir le résultat d’une requête SELECT.

Un tel objet possède la méthode next.

Cette méthode ne prend pas d’argument et revoie vrai (s’il y a au moins une ligne) ou faux.

Cours JSP 44

Exploitation des résultats

 Cet objet possède aussi des méthodes qui permettent de consulter le contenu de la ligne courante dans le résultat:  getString(nom de la colonne);    getInt(nom de la colonne); getDate(nom de la colonne); getDouble(nom de la colone); Cours JSP 45

Exemple d’utilisation du résultat

<% Out.println(‘’

’’; Out.println(‘’’’); Out.println(‘’’’); Out.println(‘’’’); While (rs.next()) { out.println(‘’’’); out.print(‘’’’); out.print(‘’’’); out.println(‘’’’); } Out.println(‘’
NomVille
rs.getString(‘’nom’’)rs.getString(‘’Ville’’)
’’; %> Cours JSP 46

Fermeture des différents élements

  À la fin de l’utilisation d’une base de donnée il est impératif d’effectuer une fermeture de cette dernière.

Cette opération de fermeture s’effectue par le message close qui doit être envoyer respectivement à ResultSet, puis à Statement et enfin à la Connection.

Cours JSP 47

Cours JSP

Exemple de fermeture

   rs.close; req.close; cnx.close; 48

Exécution d’un INSERT ou d’un UPDATE

  Pour effectuer une requête de modification (insert, update), on demande au Statement la méthode executeUpdate en lui passant la requête SQL à effectuer.

On obtient en résultat le nombre de lignes qui ont été affectées par la requête. Cours JSP 49

Exemple d’INSERT

Int nbLignes = req.executeUpdate (‘’INSERT INTO client VALUES (3,’Ali’, ‘Mohamed’, ‘Constantine’); Cours JSP 50

Exemple d’UPDATE

Int nbLignes = req.executeUpdate (‘’UPDATE client SET ville = ‘Annaba’ WHERE nom = ‘Ali’); Cours JSP 51