Industrialisation des développements AJAX - J2EE



Documents pareils
Mise en œuvre des serveurs d application

Quelques patterns pour la persistance des objets avec DAO DAO. Principe de base. Utilité des DTOs. Le modèle de conception DTO (Data Transfer Object)

Types d applications pour la persistance. Outils de développement. Base de données préexistante? 3 modèles. Variantes avec passerelles

RAPPORT DE STAGE GWT PRISE EN MAIN SERVLET - TEST DES DAO TELOSYS PLUGIN ECLIPSE WIZARD DATASET TELOSYS

TP JEE Développement Web en Java. Dans ce TP nous commencerons la programmation JEE par le premier niveau d une application JEE : l application web.

Point sur les solutions de développement d apps pour les périphériques mobiles

Programmation Web. Madalina Croitoru IUT Montpellier

Programme «Analyste Programmeur» Diplôme d état : «Développeur Informatique» Homologué au niveau III (Bac+2) (JO N 176 du 1 août 2003) (34 semaines)

les techniques d'extraction, les formulaires et intégration dans un site WEB

Architecture Orientée Service, JSON et API REST

CQP Développeur Nouvelles Technologies (DNT)

Architecture JEE. Objectifs attendus. Serveurs d applications JEE. Architectures JEE Normes JEE. Systèmes distribués

Refonte front-office / back-office - Architecture & Conception -

4. Utilisation d un SGBD : le langage SQL. 5. Normalisation

INTERNET est un RESEAU D ORDINATEURS RELIES ENTRE EUX A L ECHELLE PLANETAIRE. Internet : interconnexion de réseaux (anglais : net = réseau)

Expert technique J2EE

Institut Supérieur de Gestion. Cours pour 3 ème LFIG. Java Enterprise Edition Introduction Bayoudhi Chaouki

Compte Rendu d intégration d application

Développer des Applications Internet Riches (RIA) avec les API d ArcGIS Server. Sébastien Boutard Thomas David

JOnAS 5. Serveur d application d

THÉMATIQUES. Comprendre les frameworks productifs. Découvrir leurs usages. Synthèse

XML par la pratique Bases indispensables, concepts et cas pratiques (3ième édition)

Avant-propos 1. Avant-propos Organisation du guide À qui s'adresse ce guide?...4

AJAX. (Administrateur) (Dernière édition) Programme de formation. France, Belgique, Suisse, Roumanie - Canada

Magento. Magento. Réussir son site e-commerce. Réussir son site e-commerce BLANCHARD. Préface de Sébastien L e p e r s

Cursus Sage ERP X3 Outils & Développement. Le parcours pédagogique Sage ERP X3 Outils et Développement

Module BD et sites WEB

S7 Le top 10 des raisons d utiliser PHP pour moderniser votre existant IBM i

Cours en ligne Développement Java pour le web

WEB & DÉVELOPPEMENT LES BASES DU WEB LE LANGAGE HTML FEUILLES DE STYLES CSS HISTORIQUE D INTERNET ET DU WEB LES DIFFÉRENTS LANGAGES

1.2 - Définition Web 2.0 ( wikipedia )

Les grandes facettes du développement Web Nicolas Thouvenin - Stéphane Gully

Environnements de Développement

D une part, elles ne peuvent faire table rase de la richesse contenue dans leur système d information.

Applications distribuées: le retour du client "riche"

Devenez un véritable développeur web en 3 mois!

Petite définition : Présentation :

Formation Webase 5. Formation Webase 5. Ses secrets, de l architecture MVC à l application Web. Adrien Grand <jpountz@via.ecp.fr> Centrale Réseaux

Président d Inotekk Gestion de la société, développement du portefeuille clients, gestion et réalisation des projets informatiques

Développement d'applications Web HTML5 L'art et la manière avec Visual Studio 2015 et TFS

Programme scientifique Majeure ARCHITECTURE DES SYSTEMES D INFORMATION. Mentions Ingénierie des Systèmes d Information Business Intelligence

La persistance des données dans les applications : DAO, JPA, Hibernate... COMPIL 2010 francois.jannin@inp-toulouse.fr 1

Architecture N-Tier. Ces données peuvent être saisies interactivement via l interface ou lues depuis un disque. Application

Alfstore workflow framework Spécification technique

Formation : WEbMaster

Auto-évaluation Aperçu de l architecture Java EE

Mercredi 15 Janvier 2014

> + Consultant / Architecte JEE Indépendant. Fabien GUIBERT 34 ans, 11 ans d expérience d expérience COMPETENCES / DOMAINES METIERS

1 JBoss Entreprise Middleware

Assurances & Mutuelles, Industrie, Santé, Énergie, Transport, Médias / Multimédias, Télécoms, Services

Catalogue des Formations Techniques

Cours Plugin Eclipse. Université Paris VI / Parcours STL / Master I Pierre-Arnaud Marcelot - Iktek - pamarcelot@iktek.com

Objectif : Passer de l analyse métier et fonctionnelle à la définition des applications qui

Failles XSS : Principes, Catégories Démonstrations, Contre mesures

Introduction à. Oracle Application Express

Tutoriel: Création d'un Web service en C++ avec WebContentC++Framework

Un serveur d'archivage

Outil de planification en ligne pour des créations de rendez-vous ou de sondage

Moderniser. le système d information et le portefeuille applicatif.

Principales failles de sécurité des applications Web Principes, parades et bonnes pratiques de développement

Serveur d'application Client HTML/JS. Apache Thrift Bootcamp

Technologies Web. Ludovic Denoyer Sylvain Lamprier Mohamed Amine Baazizi Gabriella Contardo Narcisse Nya. Université Pierre et Marie Curie

Cours Bases de données

Web Tier : déploiement de servlets

DotNet. Plan. Les outils de développement

AngularJS pour une application d'entreprise

Olivier Deheurles Ingénieur conception et développement.net

Celui qui vous parle. Yann Vigara

Introduction à la plateforme J2EE

Code Produit Nom Produit Dernière mise à jour. AM003 Alias Mobile On Demand Licence 1 mois 27/04/2015

de logiciels Web 2.0, SaaS Logiciels collaboratifs Portails pour entreprises Développement iphone, Android WebApp HTML5 Mobile marketing

Java Aspect Components (JAC)

Architectures web/bases de données

Projet 2. Gestion des services enseignants CENTRE D ENSEIGNEMENT ET DE RECHERCHE EN INFORMATIQUE. G r o u p e :

Java et les bases de données

1. Installation d'un serveur d'application JBoss:

Vérifier la qualité de vos applications logicielle de manière continue

INGÉNIEUR LOGICIEL JAVAEE / GROOVY 8 ANS D EXPÉRIENCE

Application Web et J2EE

Europa. Développement JEE 5. avec Eclipse. K a r i m D j a a f a r. A v e c l a c o n t r i b u t i o n d e O l i v i e r S a l v a t o r i

7 villa de la citadelle Né le 13 mai Arcueil Nationalité : Française. Développeur Web JEE COMPÉTENCES

Projet de développement

CORBA. (Common Request Broker Architecture)

PRODUCTS LIST (updated 11th January 2010)

Le stockage local de données en HTML5

Intégration du Web 2.0 dans les solutions IBM

Composants Logiciels. Le modèle de composant de CORBA. Plan

DSL. Domain Specific Language. À l'aide des technologies Eclipse Modeling. Goulwen Le Fur Le 23 novembre 2012

Cursus Sage ERP X3 Outils & Développement. CURSUS Sage ERP X3 Outils & Développement ADVANCED. Outils avancés. 2 jours X3A-ADM. Développement 1 &2

BES WEBDEVELOPER ACTIVITÉ RÔLE

Plan. Department of Informatics

Augmenter la disponibilité des applications JEE grâce au clustering : Le projet open source JShaft

SQL Server Installation Center et SQL Server Management Studio

Langage HTML (2 partie) <HyperText Markup Language> <tv>lt La Salle Avignon BTS IRIS</tv>

LANGAGUE JAVA. Public Développeurs souhaitant étendre leur panel de langages de programmation

NFP111 Systèmes et Applications Réparties

4. SERVICES WEB REST 46

SITE WEB E-COMMERCE ET VENTE A DISTANCE

Notre Catalogue des Formations IT / 2015

Transcription:

Industrialisation des développements AJAX - J2EE Laurent Guérin ( lguerin@sogeti.com ) 25 Janvier 2007 - «Les Jeudis de l objet» Ecole des Mines de Nantes 1 - Retour d expérience & naissance d un framework 2 - AJAX 3 - Telosys Jeudis de l'objet - EMN - 25/02/2007 1

1.1 - Constats Constats Statistiques du Standish Group CHAOS Report 2004 18% 29% Succès Dépassement Abandon 53% Quelques constantes : Productivité insuffisante (manque d outils) Faiblesse des tests (unitaires, fonctionnels, couverture) Problème d estimation des charges (activité peu prédictible) Mauvaise gestion des risques Pas (ou trop peu) de «capitalisation du savoir faire» Industrialisation des développements AJAX/J2EE - Laurent GUERIN 4 Jeudis de l'objet - EMN - 25/02/2007 2

Architectures «web n-tiers» Tendance forte : «webiser» les applications métier pour Réduire les coûts de déploiement et de gestion de parc Rendre les applications accessibles à partir de postes de travail banalisés utilisation en mode «extranet» Mais le «web traditionnel» a atteint ses limites Ergonomie inadaptée aux applications à usage intensif Le «client léger» est de plus en plus «riche» ( plus complexe ) Utilisation croissante de technologies de type AJAX Projets complexes, parfois chaotiques Industrialisation des développements AJAX/J2EE - Laurent GUERIN 5 Architectures «web n-tiers» Environnement souvent complexe => Compétences multiples UML Design Patterns navigateur Réseau application navigation persistence façade services métier objets métier framework 1 framework 2 framework 3 HTML, CSS JavaScript, DOM, DHTML, XML/XSL, Java, C#, L3G! SQL Industrialisation des développements AJAX/J2EE - Laurent GUERIN 6 Jeudis de l'objet - EMN - 25/02/2007 3

Architectures «web n-tiers» La productivité a régressé! Productivité COBOL L3G C/C++ Client - serveur L4G 1970 1980 1990 2000 Années Web n-tiers Proportion de code technique encore trop importante! Industrialisation des développements AJAX/J2EE - Laurent GUERIN 7 Objectifs Accroître la productivité Améliorer la qualité Favoriser la capitalisation des composants et des compétences Combler le vide du «client léger riche» répondre aux attentes : des utilisateurs (meilleure ergonomie) des développeurs (environnement de développement simple et efficace) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 8 Jeudis de l'objet - EMN - 25/02/2007 4

Démarche d industrialisation 3 axes de rationalisation des développements «n-tiers/j2ee» Industrialisation des développements AJAX/J2EE - Laurent GUERIN 9 Démarche d outillage Détecter & éviter une situation classique : le «syndrome du bûcheron» S attaquer aux causes plutôt qu aux effets mettre en place les outils adaptés Coût initial Mais le retour sur investissement peut être important et rapide ( loi des 20/80 ) Ne pas chercher à tout industrialiser Mesurer le coût d exploitation des outils Adopter une démarche d amélioration progressive ( principe du «Kaïsen» ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 10 Jeudis de l'objet - EMN - 25/02/2007 5

1.2 Un projet de migration technologique vers AJAX/J2EE Situation initiale «client/serveur» Protocole propriétaire Déploiement Run - time Ecrans «classiques» Industrialisation des développements AJAX/J2EE - Laurent GUERIN 12 Jeudis de l'objet - EMN - 25/02/2007 6

Cible standards Suppression des «run-times» Adoption de «standards» «client léger» suppression des contraintes de déploiement Industrialisation des développements AJAX/J2EE - Laurent GUERIN 13 AJAX, une histoire ancienne? Le projet cité en exemple débute en 2003 Les choix technologiques ( «XML/http» via le composant «XMLHttpRequest» ) sont basés sur des retours d expérience des années 2001 et 2002 : Navigateur : Internet Explorer Serveurs de tous types : Java (J2EE) Microsoft ASP PHP «AJAX» : seul le nom est récent! Industrialisation des développements AJAX/J2EE - Laurent GUERIN 14 Jeudis de l'objet - EMN - 25/02/2007 7

Contraintes et moyens Contraintes fortes : Logiciel «lourd» : 210 écrans, 64 éditions, batchs, Portabilité : bases de données, serveurs J2EE, O.S. Usage intensif : IHM riche préserver l ergonomie Autres : internationalisation, capacité réseau limitée, capacité à monter en charge... Moyens limités : 450 j/h de réalisation et tests unitaires Equipe : majorité de débutants / J2EE Points positifs : Comportement stéréotypé des écrans et des éditions Industrialisation possible Industrialisation des développements AJAX/J2EE - Laurent GUERIN 15 Démarche d industrialisation Phase de «R&D» en amont du projet noyau du framework Processus d enrichissement continu Réalisation d un générateur de code Stabilisation de l équipe (pour appropriation du cycle de développement et des outils) Normes, méthodes, «best practices», Industrialisation des développements AJAX/J2EE - Laurent GUERIN 16 Jeudis de l'objet - EMN - 25/02/2007 8

Organisation et méthodes Spécialisation Stabilité Outils Cadre Refactoring Normes Itérations Prototypes Généralisation Améliorations Kaïsen Industrialisation des développements AJAX/J2EE - Laurent GUERIN 17 Architecture Web classique? Pattern «MVC» ou «MVC 2»? Inadapté au contexte Utilisateur Requête <form> GET/POST Réponse 1 5 Page complète Servlet forward JSP 3 2 use Bean 4 Réaffichage! Pas de requêtes transparentes Données utiles : 10 à 20 % du volume de la page! Maintien de contexte détaillé ( postback ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 18 Jeudis de l'objet - EMN - 25/02/2007 9

Le socle technique Framework spécifique, adapté au besoin : global ( écrans base de données ) orienté «écrans» ( principe de dialogue «client / serveur» ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 19 Cadre & outillage Organisation Cadrage Génération de code + plugins Normes Industrialisation des développements AJAX/J2EE - Laurent GUERIN 20 Jeudis de l'objet - EMN - 25/02/2007 10

1.3 Bilan du projet Portabilité vers le «Web» Les «applications métier» à usage intensif peuvent être portées vers des postes de travail de type «client léger» sans dégrader leur ergonomie, mais L interface Web ne peut se satisfaire du HTML de base! Il est souvent indispensable de fonctionner dans un mode «client serveur» ( => AJAX ) La complexité induite par la technologie AJAX doit être encapsulée dans le socle technique (non visible par le développeur) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 22 Jeudis de l'objet - EMN - 25/02/2007 11

XML / http ( AJAX ) Découplage total entre le poste de travail et le serveur Application «orientée écrans» ( et non «navigation de pages» ) ergonomie très réactive, sessions multi-écrans, contrôles champ par champ, idéal pour les «applications métier» ( usage intensif ) Uniquement du XML dans les flux de données? Approche trop «puriste»? Complexe à traiter «côté client» dans certains cas exemple : mise en forme de listes ( JavaScript inefficace => XSL! ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 23 XML / http ( AJAX ) Ne pas «abuser» des requêtes AJAX Penser à la montée en charge Contrôles champ par champ suffisant Contrôles sur saisie de caractères excessif! Localisation des traitements : Est-il judicieux de coder des «règles métier» en JavaScript? Equilibre à trouver : - Contrôles de surface côté client ( JavaScript ) - Règles métier côté serveur ( Java ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 24 Jeudis de l'objet - EMN - 25/02/2007 12

Industrialisation Rationalisation des développements : Framework Outils indispensable Méthode Productivité reste faible sur la couche de présentation Renforcer le socle technique et les outils Le développement JavaScript doit être professionnel! Générateurs de code : Outils relativement coûteux Doivent être souples, paramétrables et intégrés dans l environnement de développement (ex : Eclipse) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 25 Les limites du navigateur Ne pas essayer de tout faire dans le navigateur! Il reste de nombreux cas qu un navigateur ne peut pas résoudre Gestion du mode déconnecté Notification à l initiative du «monde extérieur» Intégration avec des solution externes (bureautique,.. ) Gestion de périphériques spécialisés Pour les cas d utilisation très complexes (ex : gestion d un diagramme de Gantt ) conserver un client lourd conserver autant que possible le protocole http Industrialisation des développements AJAX/J2EE - Laurent GUERIN 26 Jeudis de l'objet - EMN - 25/02/2007 13

Conclusions Un seul framework couvrant toutes les couches est particulièrement efficace : navigateur Réseau persistance Présentation métier framework «client» framework «serveur» Cohérence globale Economie d objets inutiles ou redondants Permet de «rapprocher l IHM des données» (comme un AGL «client / serveur» ) NB: L efficacité ne doit pas être obtenue aux dépens de l isolation des couches Industrialisation des développements AJAX/J2EE - Laurent GUERIN 27 Conclusions La plupart des «applications métier» à base de «client lourd» peuvent être «webisées» Certaines applications devront cependant conserver une partie de leur IHM en «client lourd» les architectures doivent prévoir l utilisation de postes de travail hybrides Navigateur ( AJAX ) Eclipse RCP, Swing, etc.. Requête XML http Réponse Serveur WebApp Industrialisation des développements AJAX/J2EE - Laurent GUERIN 28 Jeudis de l'objet - EMN - 25/02/2007 14

1.4 Emergence de Telosys Constat ( début 2005 ) Le principe de dialogue «client / serveur» avec «XML / http» a fait ses preuves J.J.Garrett vient de lancer le terme «AJAX» Ce principe commence à être reconnu et peut être réutilisé sur d autres projets Lancement des travaux pour préparer un framework générique : Architecture plus modulaire & outillage renforcé Simplification de la création des écrans ( bibliothèque de «TagLibs» + système de «templates» ) protocole d échange XML simple et évolutif framework JavaScript plus complet Industrialisation des développements AJAX/J2EE - Laurent GUERIN 30 Jeudis de l'objet - EMN - 25/02/2007 15

Les objectifs Accessible à des développeurs peu expérimentés dans le monde Web / J2EE (prise en main rapide) Améliorer la productivité ( capacité de développement rapide d applications ) Faciliter l utilisation des méthodes agiles/itératives (utilisable dès la phase de maquettage) Offrir une solution complète, auto-suffisante, couvrant toutes les couches Solution légère et intégrée ( plus efficace ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 31 Evolution ( 2005-2006 ) Choix du nom : «Telosys» Choix de la licence : LGPL Intégration dans ObjectWeb : Mars 2005 : premiers contacts Mai 2005 : proposé au collège des architectes Septembre 2005 : accepté 2006 : premières utilisations des versions «alpha» sur des cas d utilisation réels Industrialisation des développements AJAX/J2EE - Laurent GUERIN 32 Jeudis de l'objet - EMN - 25/02/2007 16

Site Web http://telosys.objectweb.org/ Industrialisation des développements AJAX/J2EE - Laurent GUERIN 33 2.1 - AJAX Jeudis de l'objet - EMN - 25/02/2007 17

AJAX : qu est-ce que c est? AJAX n est pas Un produit de nettoyage Un club de foot d Amsterdam AJAX n est pas non plus Une nouvelle technologie Une norme AJAX = Asynchronous JavaScript And XML un nom pour désigner l utilisation combinée de technologies existantes ( cf. article de Jesse James Garrett, février 2005) une nouvelle façon de concevoir le dialogue «navigateur serveur» «Web 2.0» Industrialisation des développements AJAX/J2EE - Laurent GUERIN 35 Modèle «AJAX» Modèle de dialogue avec le serveur beaucoup plus flexible que le modèle Web traditionnel Industrialisation des développements AJAX/J2EE - Laurent GUERIN 36 Jeudis de l'objet - EMN - 25/02/2007 18

AJAX : qu est-ce que c est? AJAX repose sur l utilisation de l objet natif «XMLHttpRequest» disponible dans les navigateurs les plus utilisés ( Firefox, Internet Explorer, Safari, ) XMLHttpRequest permet d effectuer des requêtes sur un serveur HTTP à partir de la page courante sans provoquer un rechargement de page nombreuses possibilités : effectuer des «requêtes transparentes» retrouver des concepts «client / serveur» améliorer l ergonomie etc Industrialisation des développements AJAX/J2EE - Laurent GUERIN 37 AJAX et Web 2.0 : effet de mode? «Hype Cycle for Web Technologies» ( Gartner Group 2006 ) Web 2.0 AJAX Ne pas confondre AJAX, Web 2.0 et RIA Industrialisation des développements AJAX/J2EE - Laurent GUERIN 38 Jeudis de l'objet - EMN - 25/02/2007 19

AJAX et RIA R.I.A. : «Rich Internet Application» Application Web disposant d une «ergonomie riche» Objectif : retrouver des ergonomies comparables à celles des applications «client lourd» tout en conservant les avantages du Web AJAX n est pas directement lié à RIA AJAX favorise la mise en place d ergonomies riches, Mais n apporte pas les «composants DHTML» nécessaires ( bibliothèques de «widgets» ) Les frameworks «côté client» fournissent des solutions à différents niveaux : JavaScript, AJAX, RIA, etc Industrialisation des développements AJAX/J2EE - Laurent GUERIN 39 AJAX et Web 2.0 Web 2.0 = notion floue Aucune définition ( terme créé par l éditeur O Reilly ) Désigne une nouvelle génération de sites web : version 2.0 ( par opposition au «Web 1.0»? ) Effet de mode? Caractéristiques des sites «Web 2.0» Ergonomie et look amélioré (grâce à AJAX) Syndication de contenu ( fils RSS et Atom ) Contraintes induites par l utilisation d AJAX : Problème de référencement par les moteurs de recherche Pas de gestion de l historique de navigation Pas de marquage de page dans les favoris Industrialisation des développements AJAX/J2EE - Laurent GUERIN 40 Jeudis de l'objet - EMN - 25/02/2007 20

AJAX et «applications métier» Historiques des applications métier : Ecrans passifs «mode caractères» Client Serveur Web AJAX permet : Migrations technologiques : Ecrans passifs Navigateur Client / Serveur Navigateur et/ou «poste de travail hybride» Amélioration de l ergonomie des «applications web» Applications métier non impactées par les problématiques de référencement, historique, favoris, etc Industrialisation des développements AJAX/J2EE - Laurent GUERIN 41 2.2 - AJAX Aspects Techniques Jeudis de l'objet - EMN - 25/02/2007 21

AJAX : Synchrone ou asynchrone? Synchrone : Navigateur bloqué jusqu au retour de la réponse Événements «empilés» par le navigateur Impossibilité d afficher une information visuelle pour indiquer à l utilisateur qu un traitement est en cours (problématique de rafraîchissement de l écran après interprétation du bloc JavaScript) Asynchrone : L utilisateur peut continuer à utiliser le navigateur pendant une requête Prévoir le cas des plusieurs requêtes émises en parallèle Prévoir un moyen de bloquer l utilisation du navigateur Industrialisation des développements AJAX/J2EE - Laurent GUERIN 43 AJAX : Transport des données Qu est-ce que l on transporte? Des «données» ( des «objets» ) ex : XML, POST http Des «vues» ( données déjà mises en forme par le serveur ) ex : HTML, XHTML Les objectifs : Disposer de format de données indépendants des langages de développement Véhiculer des données compréhensibles par les «deux côtés» ( client et serveur ) Eviter une analyse de flux ( «parsing» ) trop complexe ( temps de réponse, empreinte mémoire, ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 44 Jeudis de l'objet - EMN - 25/02/2007 22

Transport des données : XML En principe AJAX => XML Avantages : Standard Indépendant des langages Utilisable pour des données brutes ou des présentations ( XHTML ) Permet de transporter des objets Inconvénients : Nécessite un «parser» XML Objets => mapper/wrapper XML Industrialisation des développements AJAX/J2EE - Laurent GUERIN 45 Transport des données : Texte Le corps de la requête/réponse http peut contenir tout type de texte Données dans un format quelconque (format spécifique, «CSV», ) Du code JavaScript ( ex. Google Suggest ) : eval ( http.responsetext ) Des données au format «JSON» Industrialisation des développements AJAX/J2EE - Laurent GUERIN 46 Jeudis de l'objet - EMN - 25/02/2007 23

Transport des données : JSON JSON : JavaScript Object Notation ( http://json.org/ ) permet de représenter des éléments imbriqués { } "fullname": "Bob Dylan", "org": "Music Consulting", "emailaddrs": [ {"type": "work", "value": "bob@foo.biz"}, {"type": "home", "pref": 1, "value": "bob@foo.tv"} ], "telephones": [ {"type": "work", "pref": 1, "value": "+1 214 555 1212"}, {"type": "fax", "value": "+1 214 555 1213"}, {"type": "mobile", "value": "+1 214 555 1214"} ] notation native en JavaScript var obj = {"fullname":"bob","org":"foo"}; var obj2 = eval('(' + jsontext + ')'); autres langages (Java, C++,..) => API Industrialisation des développements AJAX/J2EE - Laurent GUERIN 47 2.3 - La problématique «JavaScript» Jeudis de l'objet - EMN - 25/02/2007 24

AJAX & JavaScript AJAX => JavaScript! JavaScript a «mauvaise réputation» Langage «non contrôlé» ( pas de compilation, faiblement typé, ) Faiblesse des outils de développement Problèmes de portabilité entre navigateurs Programmation par «copier/coller» etc... «The World's Most Misunderstood Programming Language» ( Douglas Crockford ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 49 AJAX & JavaScript Et pourtant JavaScript n est pas si mauvais JavaScript est «orienté objet» «orienté prototype» ( «prototype based» vs «class based» ) tout est objet ( même les fonctions ) dispose d «Exceptions» JavaScript est normalisé et évolue régulièrement ECMA-262 (ECMAScript) Il existe des outils & composants E4X ( ECMAScript for XML - norme ECMA-357 ) : navigation DOM «à la XPath» JavaScipt Templates ( +/- Velocity en JavaScript ) Frameworks JavaScript 1.6 Firefox 1.5 JavaScript 1.7 Firefox 2.0 Industrialisation des développements AJAX/J2EE - Laurent GUERIN 50 Jeudis de l'objet - EMN - 25/02/2007 25

JavaScript : les bonnes pratiques Développer en JavaScript comme on développe en Java Pas de variables globales ( risques de collision ) Concevoir et développer des «classes» Documenter les classes ( cf. outillage «JS-doc» ) Faire des tests unitaires Assembler les classes dans un fichier «.js» ( comme un «.jar» en Java ) Utiliser un environnement de développement adapté Exemple : Eclipse / FireFox + extensions / Ant ou Maven Mettre en place des composants ou frameworks JavaScript Industrialisation des développements AJAX/J2EE - Laurent GUERIN 51 JavaScript : les bonnes pratiques Exemple : Diagramme de classes de Telosys-JS Industrialisation des développements AJAX/J2EE - Laurent GUERIN 52 Jeudis de l'objet - EMN - 25/02/2007 26

JavaScript : les bonnes pratiques Exemple : Documentation de Telosys-JS /** * Client stub to invoke server actions * @class ScreenActions * @param Object the Screen instance * @author Laurent GUERIN */ function ScreenActions( oscreen ) {...... /** * Invokes the standard "SET" action to * update data on the server * Set all the Screen Context elements * @return Object the server response object */ this.doset = function () {...... }...... ScreenActions_class.js } Telosys «JS-DOC» Industrialisation des développements AJAX/J2EE - Laurent GUERIN 53 2.4 - Choisir un «Framework AJAX» Jeudis de l'objet - EMN - 25/02/2007 27

Frameworks AJAX Une offre pléthorique à classifier : Open Source ou Propriétaire «côté client» uniquement Orienté présentation ( effets visuels, drag & drop, widgets, ) + appels AJAX Exemples : Prototype, DOJO (JSON-RPC), script.aculo.us, OpenRico ( XML-RPC ) «côté client» et «côté serveur» AJAX Java : DWR, Echo2 (XML-RPC), Telosys (XML-RPC) AJAX PHP : CPAINT AJAX Ruby : Ruby on Rails AJAX.Net : ATLAS (Microsoft) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 55 Frameworks AJAX Positionnement des frameworks les plus connus Prototype Dojo script.aculo.us Open Rico JAVA (J2EE) navigateur Réseau Processeur de requêtes Persistance Application ( dwr/*.js ) DWR ( dwr.jar ) Echo2 ( echo2_*.jar ) ( telosys.js ) Telosys ( telosys.jar ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 56 Jeudis de l'objet - EMN - 25/02/2007 28

Frameworks AJAX Quelques critères de choix Non intrusif ( ne pas impacter les standards ) JavaScript : ECMAScript Java : Objets «pure POJO» Minimum de code (globalement & minimum de code JavaScript en particulier) Intégration avec la couche de présentation ( ex : taglibs JSP ) Préserver l interopérabilité avec des «postes de travail hybrides» échanges au format XML Industrialisation des développements AJAX/J2EE - Laurent GUERIN 57 3.1 - Le framework Telosys Jeudis de l'objet - EMN - 25/02/2007 29

Telosys Un framework conçu pour réaliser des applications métier de type Client/Server Web Principe : poste de travail de type «client http» (navigateur, ) orienté «écrans» («pages web» ) serveur qui fournit des «actions» et des «services» requêtes client/serveur «AJAX» : XML-RPC sur HTTP (seules les données utiles sont échangées) Différentes «briques» intégrées, mais utilisables séparément : Framework JavaScript Gestionnaire d écran «screen maps» Couche de persistance (mapping O/R) Gestionnaire d actions Gestionnaire de services Générateurs de code Industrialisation des développements AJAX/J2EE - Laurent GUERIN 59 Pourquoi Telosys? Répondre à la problématique des postes de travail des applications à usage intensif Associer le meilleur des deux mondes : «client léger» & «client-serveur» WebApp + Navigateur : pas de déploiement, protocoles standard, mais inadapté à une utilisation intensive Telosys voie du milieu Client / Server : orienté écran ergonomie riche, mais Protocoles Non standard + contraintes de déploiement Industrialiser les développements ( améliorer la qualité et la productivité ) réduction du «code technique»! Industrialisation des développements AJAX/J2EE - Laurent GUERIN 60 Jeudis de l'objet - EMN - 25/02/2007 30

Philosophie & principes généraux Simplicité : Placer l unique fichier telosys.jar dans le projet et l utiliser Ouverture : Utilisable avec n importe quelle autre technologie (Web Services, EJB, Hibernate, clients lourds, ), intégration avec des «servlet/jsp classiques», Struts, JSF, Couverture globale & autonomie : Toutes les couches d une application web standard sont couvertes Aucun autre framework n est nécessaire Adaptabilité : Comportement standard peut être adapté/spécialisé Proposer des solutions, ne pas les imposer! Industrialisation des développements AJAX/J2EE - Laurent GUERIN 61 Telosys : Licence & Technologies Licence : GNU Lesser General Public License (LGPL) Technologies standards : Côté Serveur : Java (Servlet, JSP, JDBC) Côté client : DHTML (HTML, Javascript, CSS) or XUL Browsers : Internet Explorer & Firefox Dialogue : XML / HTTP IDE : Eclipse + plugins Industrialisation des développements AJAX/J2EE - Laurent GUERIN 62 Jeudis de l'objet - EMN - 25/02/2007 31

Telosys : Architecture Browser (Internet Explorer, Firefox, ) HTTP J2EE Web Container UIL Screen templates Telosys ( Screen Map Server ) Screen map ( XHTML or XUL ) JavaScript Framework 1 2 HTML XUL get screen map request XML XML response authentication Screen map (JSP) RPL JavaScript Framework Business Layer Screen context JSP taglib DAL Telosys ( Request Server ) Client AJAX dialog Server Database Industrialisation des développements AJAX/J2EE - Laurent GUERIN 63 Telosys : Couches côté serveur Request Processing Layer Screen Layer Screen Application Business Layer B.S. B.O. D.A.O. XML XML Parser Screen Request Request Processor Screen Session Action Specific Action Screen Triggers XML XML Writer XmlWrapper Screen Response Screen Standard Action ScreenData Data Access Layer Screen-DAO Table-DAO Standard DAO Connection Pool POJO Screen-VO Global-VO Table-VO Commons J2EE Web Container (Tomcat, ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 64 Jeudis de l'objet - EMN - 25/02/2007 32

Telosys : différents types de clients Telosys fournit un Screen Map Server pour construire des IHM Web ( HTML / XUL ) Tout type de client http peut dialoguer avec le Request Processor ( XML-RPC ) : des applications «client lourd», quel que soit le langage (Java, C++, C#,..) ou le 4GL (Delphi, ) des serveurs (J2EE,.Net, PHP, ) etc The server side is client agnostic Navigateur ( HTML or XUL ) Application «desktop» ( Java, C, C++, C#, ) Serveur ( J2EE,.Net, PHP, )? XML HTTP J2EE Web Container Telosys Request Processor Outil de test Industrialisation des développements AJAX/J2EE - Laurent GUERIN 65 Principe de développement L indépendance des composants permet d envisager différents principes de développement : UML A partir du modèle applicatif / métier navigateur Présentation Persistance Composants applicatifs / métier IHM vers le modèle de données Modèle de données vers IHM Industrialisation des développements AJAX/J2EE - Laurent GUERIN 66 Jeudis de l'objet - EMN - 25/02/2007 33

3.2 - Persistance Telosys-DAL : Architecture Application Data Access Layer Connection getconnection() Manager init() dbconfig.xml «DAO» «SqlConnection Provider» AgencyVO AgencyDAO SqlConnection Pool SqlConnection AgencyVOList SqlConnection Pool EmployeeVO EmployeeDAO SqlConnection EmployeeVOList SqlConnection Factory SqlConnection Value Objects For each table : 1 VO & 1 VOList For each table : 1 DAO Pool or single connection Multiple databases Industrialisation des développements AJAX/J2EE - Laurent GUERIN 68 Jeudis de l'objet - EMN - 25/02/2007 34

Telosys-DAL : DAO VO VOList Exemple : table «Employe» SqlRequests. gettablename(). getsqlxxxx() EmployeVO. getxxxx(). setxxxx(). isxxxx(). tostring() POJO 0..N EmployeVOList. EmployeeVO add(). add( EmployeeVO ). insert ( index, EmployeeVO ). replace ( index, EmployeeVO ). remove ( index ). remove (EmployeeVO ). EmployeeVO get( index ). EmployeeVO getfirst(). EmployeeVO getnext() LinkedList Mapping Table - VO. load(). save(). delete(). insert(). update(). exists(). loadlist(). savelist(). deletelist(). insert(). count(). createquery() EmployeDAO ListQuery. setparameter(). getsqlselect(). getsqlcount(). getsqldelete() Industrialisation des développements AJAX/J2EE - Laurent GUERIN 69 Telosys-DAL : Générateur de code Plugin Eclipse Modèle = Base de données ( metadata ) Mapping Colonne Table Attribut Java Génération. VO. VOList. DAO Industrialisation des développements AJAX/J2EE - Laurent GUERIN 70 Jeudis de l'objet - EMN - 25/02/2007 35

3.3 - Screen Context & Actions Standards Telosys-SCL : Screen Context SCL ( «Screen Context Layer» ) : Conteneur de «Screen Context» Screen Context = assemblage d objets (éléments) gérés par les écrans de l application Un écran manipule généralement des «entités» et des «listes» un Screen Context = assemblage de VO et de VOList Pattern «SDO simplifié» Element Name Value Object Screen Context 1 à N «Elements» Element Name Element Name Value Object List Value Object Value Object Value Object Value Object Industrialisation des développements AJAX/J2EE - Laurent GUERIN 72 Jeudis de l'objet - EMN - 25/02/2007 36

Telosys-SCL : Screen Context Exemple de Screen Context : public class EmplData extends StandardScreenData { //--- Elements Names public final static String EMPLOYEE = "employee" ; public final static String AGENCY = "agency" ; public final static String PROJECTS = "projects" ; } //------------------------------------------ public EmplData() throws TelosysException { //--- Define the Screen Data Elements defineelement( EMPLOYEE, EmployeeVO.class ); defineelement( AGENCY, AgencyVO.class ); defineelement( PROJECTS, ProjectVOList.class ); } Element Name Element Type ( class ) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 73 Telosys-SCL : Screen Context Chaque utilisateur ( session http ) travaille sur 1 à N écrans simultanément donc sur 1 à N «Screen Context» 1 user Http Session Screen Session 1 http session 1 Screen Session 0..N screens Screen Context 0..N Screen Context Vue(s) Modèle(s) Industrialisation des développements AJAX/J2EE - Laurent GUERIN 74 Jeudis de l'objet - EMN - 25/02/2007 37

Telosys-SCL : Screen Action Les actions utilisateur sont soumises au serveur (en XML-RPC) qui les exécute dans un «contexte» : Action Modèle Standard Actions Screen Triggers Screen Context Screen Context Elements ACTION Screen Procedures Value Object Specific Screen Actions Screen DAO Action Implementation Industrialisation des développements AJAX/J2EE - Laurent GUERIN 75 Telosys-SCL : Screen Action Telosys fournit un jeu d actions standards pour réaliser les opérations classiques d un écran et permet d ajouter des opérations spécifiques Gestion du Screen Context : Open Close Set Get Clear Screen Context Persistance du Screen Context : Load Save Insert Delete Update Standard pas de codage (surcharge possible ) Debug : Ping Echo Appel de procédure : Exec Spécifique à implémenter Industrialisation des développements AJAX/J2EE - Laurent GUERIN 76 Jeudis de l'objet - EMN - 25/02/2007 38

Telosys-SCL : exemple d action Action «load» Client 1 load ret. code set=true get=true Data Params Server Screen Data Params Data Data Access Layer 2 load set=false get=true Params Params ret. code Data no set Data 3 load set=true get=false ret. code Params Screen Data Params Data X M L Java objects Request : default values set="true" / get="true" Response : flag found or not found Industrialisation des développements AJAX/J2EE - Laurent GUERIN 77 Telosys-SCL : Triggers Chaque exécution d action est encadrée par le déclanchement de deux triggers (avant et après) 1 beforexxx() Return true «continue» autorise l exécution de l action Return false «cancel» annule l exécution de l action ACTION 2 Traitement de L action Xxx 3 afterxxx() Return true action validée ( commit ) Return false action annulée ( rollback ) Utilisations : contrôles, règles «métier», traces, journalisation, etc Industrialisation des développements AJAX/J2EE - Laurent GUERIN 78 Jeudis de l'objet - EMN - 25/02/2007 39

Telosys-SCL : Screen Context La classe Screen Registry permet de définir les Screen Context et les composants qu ils utilisent Screen Context Screen Name Screen Data Screen DAO Screen Actions Screen Triggers Screen Procedures Données ( «éléments» ) Comportements ( «actions» ) public class ScreenRegistry extends StandardScreenRegistry public void initregistry() { // Parameters : // Name, Elements, Screen DAO, Actions, Triggers, Procedures register("s001", S001.class, S001dao.class, null, S001trig.class, S001proc.class); register("s002", S002.class, S002dao.class, null, null, null ); } Screen Name Screen Components : data + actions Industrialisation des développements AJAX/J2EE - Laurent GUERIN 79 3.4 - Dialogue Client-Serveur Jeudis de l'objet - EMN - 25/02/2007 40