JEE pour les nuls - SCIMAT3).pdf · 3 JEE pour les nuls • Ou bien : – J2EE pour les nuls –...

Post on 12-Sep-2018

303 views 3 download

Transcript of JEE pour les nuls - SCIMAT3).pdf · 3 JEE pour les nuls • Ou bien : – J2EE pour les nuls –...

1

JEE pour les nuls*

Atelier CRI du 15/01/2008

* Je laisse la responsabilité de ce titre à Alain Kermarrec ;-)

2

Licence

Ce travail est mis à disposition sous une licence Creative CommonsVous êtes libres

De reproduire, distribuer et communiquer cette création au public De modifier cette création

Cette création est mise à disposition selon le Contrat Paternité-NonCommercial-ShareAlike 2.5 disponible en ligne http://creativecommons.org/licenses/by-nc-sa/2.5/

3

JEE pour les nuls

• Ou bien :– J2EE pour les nuls– JEE pour les null– Java EE pour les nuls

• Allez on y va…

4

Java

• Langage – Objet– Multiplateforme

• Utilisation d’une JVM (Java Virtual Machine)

• JVM– JRE (Java Runtime

Environment)– JDK (Java

Development Kit)• JRE + javac + javadoc +

JavaJava

JVMJVM

OSOS

5

JAVA

• JRE– Sun (Pour Solaris, Linux, Windows), IBM (AIX, Linux,

etc.), BEA, Apple (Mac)– Microsoft (http://www.microsoft.com/mscorp/java/faq.mspx) :

• Which third-party Java Run-time Environment (JRE) doesMicrosoft recommend?

– Because Microsoft does not support third-party Java implementations, including monitoring and fixes of potential and exposed security vulnerabilities, we do not distribute or makerecommendations on these products . However, customers caninstall any compatible Java virtual machine on any computer running Microsoft Windows that they wish . Microsoft works withthird parties to ensure that they have all of the information they need for their technologies to work well in the Windows environment.

6

JAVA

• Langage objet– On crée des objets en mémoire, à partir de classes,

pour stocker de l’information et/ou exécuter des traitements

• Un objet est une instance d’une classe• Un objet est constitué d’attributs et de méthodes

• Le code source dans un .java• Javac du JDK le transforme en .class• Le .class est exécuté dans un JRE

– Un Test1.class généré sous windows fonctionnera sur Linux

– Ex : java Test1

7

Java

• On ne développe jamais seul• Des bibliothèques de classes

à tout faire existent déjà• Notre .class va faire appel à

ces classes (importer) pour créer de nouveaux objets

• Quand on va lancer notre programme la JVM devra savoir où trouver ces classes

• On parle de classpath– Ex : java -cp bin;util Test2

8

JAVA

• Pour les maniaques du rangement !• Les classes sont dans des répertoires

– Pour avoir un espace de nom propre et éviter les conflits– Par domaine pour s’y retrouver– On utilise le « . » comme séparateur de répertoires

• Exemple– org.esupportail.commons.services.smtp.AsynchronousSmtpServiceImpl– org.esupportail � utilisation du nom de domaine esup-portail.org à

l’envers (le « - » n’est pas valide)– commons � pour esup-commons– services.smtp � pour le service de mail– AsynchronousSmtpServiceImpl � Le nom de la classe avec Une

majuscule en première lettre et sur chaque mot

9

• On fait des Zip de tout ça – C’est plus pratique– Ce sont des .jar (Java Archive)

• Dans le classpath on utilise donc :– Des répertoires de Classes– Des Zip de Classes– Ex : java -cp bin;util Test3

java.lang.NoClassDefFoundError: org/apache/log4j/Logger

– Mieux : java -cp bin;util;lib/log4j-1.2.13.jar Test3

JAVA

10

Lancer java

• En général les scripts shell utilisent la variable d’environnement JAVA_HOME pour pointer vers le répertoire d’installation de java

• $JAVA_HOME/bin contient l’exécutable « java » qui va servir au lancement du programme

• Quelques options de la ligne de commande java– On a vu la gestion du classpath

• -cp path1;path2;fic1.jar:fic2.jar– On peut gérer la mémoire minimum et maximum allouée

• -Xms512m -Xmx1024m– On peut faire du debug à distance

• -Xdebug -Xrunjdwp:transport=dt_socket,address=55555,server=y,suspend=n– On peut faire de l’administration à distance

• On utilisant JMX (Java Management Extensions)• -Dcom.sun.management.jmxremote.port=9004

11

Objets et interfaces

• Objets– Attributs

• Peuvent être accessibles directement• Mais très souvent on crée des méthodes pour manipuler les

attributs (des « accesseurs »)– Meilleure maîtrise de l’évolution du contenu de l’objet– Ex : une Personne à un nom on aura une méthode pour connaître

son non � getNom()

– Méthodes• Pour manipuler les données d’un objet ou offrir un service

– Ex : raymond.travailleMaintenant() !• Une méthode un peu particulière est appelée à la création de

l’objet : Le constructeur

12

• Interfaces– Définition d’une liste de méthodes– On va pouvoir utiliser tout objet qui sait

répondre à cette liste de méthodes• On dit qu’il implémente l’interface• Ex : raymond.travailleMaintenant() devient

robot.travailleMaintenant() (☺ ou �)

– On va voir l’utilité de ce mécanisme dans les serveurs d’applications où l’on va pouvoir « brancher » des applications

Objets et interfaces

13

Revenons à Java EE

• Java ME (Micro Edition)– Je ne connais pas bien

• Java SE (Standard Edition)– On peut tout faire avec– Sert de base à Java EE

• Java EE (Enterprise Edition)– L’usine à gaz et à fric que le temps,

l’expérience et l’Open Source ont rendu accessible

14

Java EE

• C’est un gros package de technologies– Sur lesquelles je vais revenir

• JSP ; Servlet ; EJB– Ou pas

• JSF (Java Server Faces. Utilisé dans les développements ESUP et Rennes 1)

• JMS (Java Message Service)• JAX-RPC (Java API for XML-Based RPC)• Etc.

• En java, chaque technologie majeure passe par une phase ouverte de spécification– JCP (Java Community Process � http://www.jcp.org)– Production de JSR (Java Specification Request � Ex. de JSR 168

pour portlet)

15

La machine de guerre

• Comme le cadre de travail est clair tout le monde y va :– Les éditeurs (Oracle, IBM, SUN) lancent des

serveurs d’applications compatibles Java EE– Les DSI forment leurs personnels– Les SSII vendent de la prestation

• Oui mais :– Les développeurs souffrent sur certains points– Les prix sont parfois astronomiques

16

Alors ?

• JSP et Servlet sont incontournables– Apache Tomcat est un serveur d’applications (non Java

EE au sens stricte) qui ne fait que ça mais le fait bien et gratuitement

• Et pour tout le reste ?– Accès aux données � Les EJB sont trop lourds on

utilise Hibernate– On organise les développements avec un conteneur

léger comme Spring– Si on a tel ou tel besoin on va trouver en Open Source

la bibliothèque qu’il faut

17

Servlet

• C’est une classe java qui va produire le contenu d’une page Web

• Cette classe doit implémenter l’interface Servlet• Pratiquement on doit écrire, dans une méthode

précise, le code java produisant le HTML• Le serveur d’applications va savoir appeler cette

méthode– Vous vous souvenez du puzzle ?

18

JSP

• Java Server Page• Ecrire une servlet c’est bien mais c’est

encore trop compliqué– Il faut écrire une classe et la compiler

• JSP permet d’incérer facilement du JAVA dans une page HTML– C’est le serveur d’application qui va se charger

de la transformer en Servlet et de la compiler quand il le faut

19

JSP et Servlet

• Ce que je viens de vous décrire c’est du bricolage• Dans la pratique

– Les JSP servent au rendu (Vue) et font appel à des classes « métier » écrites en java (Modèle) qui appellent, à leur tour, le service de stockage de l’information (en base de données par ex.)

– Une Servlet sert à aiguiller entre les vues (Contrôleur)– On parle alors de MVC (Modèle, Vue, Contrôleur)

20

Et si on rangeait ? Ouai !

• On va mettre toutes les JSP, Servlet ainsi que les Classes et librairies qu’elles utilisent dans un .war (Web Archive)– C’est encore un zip– On y trouve toujours

• WEB-INF/– web.xml– lib/– Classes/

21

On s’y retrouve mieux ☺

• web.xml– Est un fichier XML de description de l’application– Il a une syntaxe précise– On va, par ex., y trouver le nom de la Classe (implémentant

l’interface Servlet) à utiliser pour tel ou tel chemin d’une URL Web• Lib/

– On va y mettre tous les .jar dont notre programme a besoin• Classes/

– On va y mettre toutes les .class que l’on produit• Le serveur d’applications va savoir, pour chaque

application qu’il héberge, lire le web.xml et créer automatiquement un classpath spécifique à l’application àpartir des répertoires lib et classes

22

EJB

• Enterprise Java Bean– Bean

• Objet dont les attributs ne sont accessibles que par des accesseurs et dont un des constructeurs ne prend aucun paramètre

– Java• OK

– Enterprise• Compliqué ? Solide ? Lourd ? Cher ?

• Ils sont de deux types– Les EJB session– Les EJB entité

23

EJB

• L’idée de départ (EJB 1 et 2)– Avoir des objets qui offrent des services (Les EJB

session) répartis, pour des questions de charge, sur différents serveurs

– Avoir un mécanisme standard de persistance des données contenues dans les objets (Les EJB Entité)

• Dans la pratique c’est compliqué– Besoin, pour les objets, d’implémenter une interface

particulière– Objets non utilisables hors d’un serveur Java EE– Pas facilement portable d’un serveur à un autre

24

Hibernate

• Hibernate est un exemple d’outil de mappingobjet <-> Relationnel– Le mapping est défini dans des fichiers XML– Un objet devient une ligne d’une table dans une base de données– Un attribut devient un champ de cette ligne

• Permet de stocker tout objet (pas d’interface particulière)• Utilisable hors d’un serveur d’applications Java EE

– Un simple Tomcat– Un programme batch

25

EJB 3

• EJB 3 reprend les principes d’Hibernate• Hibernate est compatibles avec EJB 3• L’honneur est sauf et les DSI restent en poste ;-)• EJB 3 est surtout focaliser sur l’enregistrement

des données– JPA (Java Persistence API)

• EJB 3 (JSR 220) fait parti de Java EE 5– Faites moi penser à vous parler de versions !

26

Et les EJB session ?

• Les Web Services mais aussi les framework MVC et les conteneurs légers font qu’ils n’ont plus besoin d’exister en tant que tel

• Un Web Service– « C’est un EJB session » sauf que l’on utilise

HTTP pour communiquer et qu’il n’est pas obligatoirement écrit en java

27

Conteneur léger

• Son rôle est de créer automatiquement des objets et de les mettre en relation– C’est ce que fait un serveur Java EE !– Mais il est léger :

• Pas besoin, pour les objets manipulés, d’implémenter une interface particulière

• Utilisable hors d’un serveur Java EE (Tomcat, Batch)• Il est tellement léger qu’il est intégré dans l’application et que

son utilisation impacte seulement les développeurs, pas les exploitants

• Permet de facilement changer un morceau (de puzzle) par un autre

• Ex. de Spring très apprécié des développeurs

28

ESUP-Commons

• Ou comment fabriquer un pseudo serveur Java EE commun

• Une démarche– Esup-blank– Des outils communs– Du rangement

• Une librairie• Une formation• Une communauté

29

ESUP-Commons, le puzzle

Gestion

des beans

dataw

eb

Présentation

Logique applicative

Logique métier

Données

Persistance

Requêtes web

base

LDA

P

portail

UR

Ls

I18n

Cache

Accès

Auth.

30

Les versions de java

• 1.2– Quel est l’idiot qui a oublié de changer le premier numéro ?– Que sera la version 2.0 ?– J2SE 1.2, J2EE 1.2

• 1.3– J2SE 1.3, J2EE 1.3

• 1.4– J2SE 1.4, J2EE 1.4

• 1.5– J2SE 1.5, Java EE 5

• 1.6– Java SE 6

• En général les scripts shell utilisent la variable d’environnement JAVA_HOME pour savoir quelle version de java utiliser pour lancer un programme donné

31

Qu’ai-je oublié ?

• J’ai parlé Servlet (Classe java qui fonctionne dans un serveur d’applications) mais :– C’est quoi un Portlet ?– C’est quoi une Applet ?

• Les exceptions

32

C’est quoi un Portlet ?

• Une classe java (conforme à la JSR 168) qui tourne dans un portail– Le but est d’avoir sur une même page Web

plusieurs applications (portail)– C’est sous forme d’un .war comme une

application Web avec un WEB-INF/portlet.xml en plus

– L’interface à implémenter n’est plus Servletmais Portlet

33

C’est quoi une Applet

• C’est une classe java qui tourne dans une JVM intégrée au navigateur Web et qui s’exécute sur le poste client– C’est sous forme d’un .jar que le navigateur va

télécharger sur le web– Je n’en sais pas plus

34

Les exceptions

• En java quand quelque chose se passe mal on a une exception– java.lang.NullPointerException– java.io.FileNotFoundException

• Pour le développeur c’est pratique– Il essaie (try) des choses– Il attrape (catch) des exceptions pour éventuellement

les traiter– Et s’il ne sait pas faire il soumet (throw) le problème au

chef (en fait, la méthode qui l’appelle dans la pile d’exécution (stack))

35

Les exceptions

• Ce sont aussi des objets avec des méthodes pour connaître :– La cause

• En générale on lève une exception parce que l’on a eu un autre problème avant

• org.esupportail.lecture.exceptions.dao.XMLParseException à cause d’une org.dom4j.DocumentException

– Le message• org.dom4j.DocumentException: Connection refused

– La pile d’exécution• org.dom4j.DocumentException: Connection refused

org.dom4j.io.SAXReader.read(SAXReader.java:484)• org.dom4j.io.SAXReader.read(SAXReader.java:321)• org.esupportail.lecture.dao.FreshSourceThread.getFreshSource

(FreshSourceThread.java:81)• org.esupportail.lecture.dao.FreshSourceThread.run

(FreshSourceThread.java:57)

36

Travaux pratiques

• ANT• Voir une config Spring• Voir une config log4j• Eclipse et SVN

37

ANT

• ANT est un outil permettant d’automatiser des tâches (comme make utilisé sous Unix)

• Le fait qu’il soit écrit en java permet qu’il soit utilisable sur toutes les plateformes disposant une JVM

• Le principe repose sur des cibles (target) décrites dans un fichier XML (build.xml le plus souvent)– Les cibles peuvent avoir des relations de dépendance

entre elles– Elles peuvent faire référence à des propriétés

contenues dans un(des) fichier(s) de propriétés facilement éditable(s) (par un exploitant par ex.)

38

ANT

• Les cibles ont à leur disposition des tâches (task) pour effectuer différentes actions :– echo, mkdir, copy, replaceregexp, jar, javac, javadoc, etc.

• Les tâches agissent sur des ensembles de fichiers :– fileset, pathelement, etc.

• Mode de lancement de ANT– ant � exécute la cible par défaut (utilisation du build.xml du

répertoire courant)– ant –p � donne la liste des cibles disponibles– ant deploy � lance la cible « deploy » en charge d’installer

(déployer) une application– ant deluser -Duser=toto � lance la cible « deluser » de

suppression du user toto de la base de données du portail

39

ANT

• Un exemple de cible :

40

Spring

• Spring est un conteneur léger– Son rôle est de créer des objets et de les mettre en

relation• Le développeur utilise des objets mais il n’écrit plus le code de

création de ces objets• Il demande à Spring de les lui fournir

– Spring permet de facilement changer un morceau (de puzzle) par un autre

• Si un développeur a besoin d’un objet pour envoyer du mail• Et qu’une interface définie que l’envoi de mail se fait en

utilisant une méthode de nom send• Le développeur a juste besoin d’appeler cette méthode• Spring va se charger de créer le bon objet au bon moment

41

Spring

• Va appeler les objets qu’il gère des beans• La définition de ces beans se fait dans un fichier XML• Le développeur ne s’occupe plus de ça (il veut juste

envoyer un mail)– Il n’a même plus à se soucier du traitement du fichier de

configuration contenant l’adresse du serveur de mail– Vous comprenez pourquoi je vous disais que les développeurs

aimaient Spring ;-)

• L’exploitant a accès à ce fichier XML et peut tout changer– S’il le veut il peut même envoyer les mails dans une base de

données pour archivage et ne plus utiliser SMTP

42

Spring

43

Spring

• On peut centraliser le paramétrage

44

log4j

• Log for Java• Depuis java 1.4 il existe, en standard dans la

JVM, un mécanisme de log qui ressemble beaucoup à ce qui existait déjà avec log4j

• Apache commons logging met tout le monde d’accord en offrant une surcouche au développeur

• Le développeur logue tout :– Les erreurs (ERROR), les avertissements (WARN), des

informations plus ou moins importantes pour l’exploitant (INFO) ou lui (DEBUG)

45

log4j

• C’est l’exploitant ensuite qui décide de ce qu’il garde, oùet comment– Grace à un fichier log4j.properties ou log4j.xml qu’il met à la racine

du classpath (emplacement par défaut) ou dans properties/logging(pour un développement esup-commons)

– Il a sa disposition des appenders (où seront envoyés les logs)• Fichiers tournants ou pas• Syslog• Etc.

– Il décide de quelles classes il veut les logs en précisant• L’appender à utiliser• Le niveau de log souhaité

– ERROR, WARN, INFO, DEBUG

46

log4J

47

Eclipse

• Eclipse est un IDE écrit en java qui permet, entre autres choses, de développer en JAVA– Coloration syntaxique, auto-complétion, vérification des erreurs à

la volée, etc.• Il est très modulaire et permet de facilement éditer

différents type de fichiers grâce à différents plugins– Editeur XML générique– Editeur ANT– Editeur Spring– Etc.

• Il offre aussi des outils intéressants– Navigateur LDAP ou SQL– Client SVN

48

SVN

• SubVerSion est un outil de gestion des versions– Très utilisé par les développeurs il pourrait

(devrait ?) l’être par les exploitants pour gérer leurs fichiers de configuration

– Quand un développeur n’utilisant pas SVN le découvre après avoir longtemps résisté, il se demande comment il a pu s’en passer

49

• C’est simple !– Checkout � on prend ce qui est sur le serveur

pour le mettre en local– Update � on met à jour ce qui est local avec

ce qui est sur le serveur– Commit � on met à jour le serveur avec ce qui

a été modifié en local

SVN

50

• On peut faire un tag � C’est juste une copie, une image à un moment donné, de ce qui est sur le serveur (ex : version mise en prod le 01/04/2007)

• Quand ça ne marche plus :– On a des outils pour voir ce qui a changé depuis telle

date, tel tag– On peut revenir (switch) à l’image à une date, un tag

• On peut facilement travailler à plusieurs :– Au pire on devra faire une fusion (merge) et décider

laquelle des deux modifications est la plus pertinentes

SVN

51

SVN

52

Conclusion

• Java c’est :– Tentaculaire, passionnant, structurant

• Donc java peut rendre :– Insomniaque, psychorigide, maniaque

• Vous êtes prévenus. Faites attention !