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.close(); } Cours JSP 4Cours 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
;
;
;
;
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
<% 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
Quantite | Prix |
---|---|
’’); out.print(qtes[i]); out.print( | ); out.print(‘’’’); out.print(prix[i]); out.print( |
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(‘’
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(‘’
Nom | Ville | ’’); Out.println(‘’
---|---|
rs.getString(‘’nom’’) | ’’); out.print(‘’rs.getString(‘’Ville’’) | ’’); out.println(‘’
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