Nicolas Pastorelly. Nicolas.pastorelly@unice.fr



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

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

DotNet. Plan. Les outils de développement

Vulgarisation Java EE Java EE, c est quoi?

Java pour le Web. Cours Java - F. Michel

Java et les bases de données: JDBC: Java DataBase Connectivity SQLJ: Embedded SQL in Java. Michel Bonjour

Comparaison des architectures J2EE et.net

Mise en œuvre des serveurs d application

Cedric Dumoulin (C) The Java EE 7 Tutorial

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

24/11/2011. Cours EJB/J2EE Copyright Michel Buffa. Plan du cours. EJB : les fondamentaux. Enterprise Java Bean. Enterprise Java Bean.

Plan. Department of Informatics

Urbanisation et architecture des systèmes d information

Java et les bases de données

Module BD et sites WEB

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

Compte Rendu d intégration d application

Présentation J2EE. Stéphane Croisier, Directeur Serge Huber, Directeur Technique. 13 Juin Jahia Ltd. All rights reserved.

Technologies DotNET. Vision de Microsoft

J2EE - Introduction. Développement web - Java. Plan du chapitre

Software Engineering and Middleware A Roadmap

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)

JOnAS 5. Serveur d application d

Programmation Web Avancée Introduction aux services Web

Jahia. Guillaume Monnette École Ingénieurs 2000 Marne-La-Vallée IR3

DotNet. Présentation de l'offre

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)

Nouvelles Plateformes Technologiques

Web Tier : déploiement de servlets

NFP111 Systèmes et Applications Réparties

Connexion à SQL Server 2005 à partir du serveur d application SJSAS 9 Utilisation d une interface JDBC

Introduction à la plateforme J2EE

Environnements de Développement

Architectures n-tiers Intergiciels à objets et services web

Systèmes répartis. Fabrice Rossi Université Paris-IX Dauphine. Systèmes répartis p.1/49

OpenPaaS Le réseau social d'entreprise

Introduction aux «Services Web»

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

Architectures web/bases de données

Java - la plateforme

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

Ré-architecture et migration d une application standalone vers un serveur applicatif multi-tiers dans un contexte JAVA-SAP

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

10. Base de données et Web. OlivierCuré

Rafraichissement conditionné d'une page en.net

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars

Module.NET 3 Les Assemblys.NET

Principes. 2A-SI 3 Prog. réseau et systèmes distribués 3. 3 Programmation en CORBA. Programmation en Corba. Stéphane Vialle

Remote Method Invocation (RMI)

Java DataBaseConnectivity

as Architecture des Systèmes d Information

Cours Master Recherche RI 7 Extraction et Intégration d'information du Web «Services Web»

Messagerie asynchrone et Services Web

La technologie Java Card TM

Virginie!SALAS Janvier!09! NFE107

2 Chapitre 1 Introduction

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

JOnAS Day 5.1. Clustering

Urbanisme du Système d Information et EAI

Création d une application JEE

Initiation à JAVA et à la programmation objet.

RMI le langage Java XII-1 JMF

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

Apache Camel. Entreprise Integration Patterns. Raphaël Delaporte BreizhJUG

Systèmes d'informations historique et mutations

Apache Tomcat 6. Guide d'administration du serveur Java EE sous Windows et Linux. Résumé. Étienne LANGLET

Hébergement de sites Web

4. SERVICES WEB REST 46

Urbanisation des Systèmes d'information

RN2-Programmation Orientée Objet - JAVA CH 1 Introduction à la POO et Java

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

Projet. But: consultation en temps réel d événements (cours de bourse, trafic d envoi SMS ) sur des téléphones portables. Serveur de diffusion

SOAP Concepts Application à Glassfish

Architecture Orientée Service, JSON et API REST

Evaluation Idéopass Cahier d analyse technique

Notre Catalogue des Formations IT / 2015

Jean-Philippe VIOLET Solutions Architect

Le cadre des Web Services Partie 1 : Introduction

CAHIER DES CHARGES D IMPLANTATION

Urbanisation des SI. Des composants technologiques disponibles. Urbanisation des Systèmes d'information Henry Boccon Gibod 1

Les processus métiers : concepts, modèles et systèmes

Plan du cours. Historique du langage Nouveautés de Java 7

Alfstore workflow framework Spécification technique

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

Java Enterprise Edition

Le modèle client-serveur

Installer Enterprise Miner 5.1 en SAS environnement Windows

Java Aspect Components (JAC)

Oracle Maximum Availability Architecture

L intégration d applications unifiée par les Services Web et XML Réconcilier J2EE.NET EIS et mainframes

Java c est quoi? Java. Java. Java : Principe de fonctionnement 31/01/ Vue générale 2 - Mon premier programme 3 - Types de Programme Java

<Insert Picture Here> Maintenir le cap avec Oracle WebLogic Server

Patrons de Conception (Design Patterns)

Application Web et J2EE

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

SOA Open Source Intégration des services et business process dans une architecture SOA Open Source. Bruno Georges JBoss, a Division of Red Hat

Machine virtuelle Java pour Palm TX

Le serveur HTTPd WASD. Jean-François Piéronne

BPEL Orchestration de Web Services

Transcription:

Nicolas Pastorelly Nicolas.pastorelly@unice.fr

Objectif du cours Applications N-tiers Reconnaître les différents types d architectures Connaître les critères de choix lors de la création d une application Comparaison : Visions : Sun ONE &.NET Comparaison couche à couche des infrastructures

Les différentes architectures Les types d architectures dépendent du type et du nombres de serveurs impliqués Les diverts types d architectures ont différents avantages et désavantages Généralement sont distinguées les architectures 2-tiers 3-tiers n-tiers Ce qui compte (/ aux objectifs) La rapidité Facilité de mise en place / administration

Les architectures 2 tiers Type le plus ancien d applications réseau avec la plus part du temps : Un serveur De multiples clients Les fonctionnalités sous souvent hébergées par le serveur Le client est un client léger Relation maître - esclave Traitements 1 Données 2

Les architectures 2 tiers & clients lourds Le prix de la ressource informatique diminuant, le client put assumer un partie du traitement client lourd PB : installation & maintenance du client Traitements 1 Données 2 Traitements

Evolution des architectures Les ordinateurs se répondant dans les bureaux, les demandes d applications augmentèrent rapidement Besoin de nombreux serveurs & sources de données Les «applications d entreprise» virent le jour Résultat : de nombreux domaines adressés s & une complexité croissante qui rendirent nécessaire n la division des applications en couches ou tiers Legacy App Centralized Mainframe/Mini SNA Channel Attach Terminals Pas de Client/serveur monolithique Distributed PC LAN/WAN TCP/IP, Ethernet GUIs Client Lourd/serveur - Client Léger/serveur

Architecture 2 tiers & WEB Avec l arrivée d Internet le modèle client/serveur prit son envol Client lourd = mail, newsgroups, P2P Client léger = client browsers 1 ère génération d architecture Serveur Web Simple Affichage HTML (Browser Web) Serveur Web 1 2 Problèmes & limitations : Bon pour du simple affichage Données non dynamiques HTTP Pages HTML

Les architectures 3 tiers classiques Un serveur d application est entre le client & la source de donnée 3 processus exécutés sur des plateformes différentes Tiers Client Tiers du milieu Tiers de données 1 2 3 Protocole propriétaire ou standard Interface client (Traitements)? héberge les processus de traitement fonctionnels (Génère des données d affichage)? Appelé application serveur RDBMS ou autres

Les architectures WEB 3 tiers classiques Affichage HTML (Browser Web) Applet, ActiveX Clients lourds Applet, ActiveX 1 2 Serveur Web Problèmes & limitations : CGI scaling Gestion de différents types de clients Gestion de la cession HTTP Sécurité Module Pages HTML Corba/RMI, COM CGI, Pages serveur Tiers de données 3 RDBMS Directory, mail serveur, SMTP Applications d entreprises Autres

Rappel : Common Gateway Interface (CGI) Certains fichiers sont interprétés s comme programmes en fonction de leur extensions ou emplacement Les programmes invoqués s génèrent g en entête MIME est du contenu HTML sur stdout 2 Web-Server 1 HTTP-Request Load File File-System HTML-File HTML HTML? File Output Program? Executer le Programme Tiers de données I/O, Network, DB 3

Les architectures 3 tiers Avantages Facile rapide à mettre en place Facile à administrer Utile pour des applications simples Désavantages Tolérance à la faute (un seul point critique) Montée e en charge difficile Pb de maintenance / évolution Pas réellement r flexible (logiques de présentation et de connexion mélangm langées)

Les architectures N tiers N tiers = Un nombre de tiers supérieur à 3 N tiers =Utiliser une combinaison de serveurs & couches logicielles pour créer un collection modulaire de services informationnels Concevoir l application en utilisant autant de «tiers» que nécessaire Compatible avec les techniques de conception OO Pouvoir mettre les composants créés dans les serveurs choisis

Les architectures N tiers Avantages Application plus puissantes De nombreux services pour de nombreux clients Gestion de la sécurité, disponibilité, évolution (scalability( scalability) Désavantages Plus compliqué à concevoir Risques de performances Robustesse difficile à garantir Les Attributs de qualité : Robustesse : difficile avec une application + complexe Sécurité : les tiers sont autant de barrières Disponibilité : découpage en tiers permets la redondances Evolution : couche = facile d ajouter de nouveaux services Maintenance : difficile avec une application + complexe

Les architectures N tiers Une architecture N tiers peut être évaluée suivant l axe Logique Couches, composants métiers créés Physique Installation sur différents serveurs des différentes couches logiques Architecture classique : 4 tiers Tiers de données Tiers Client 1 Serveurs de Application présentation serveurs 2 3 BD réplication 4 Serveur mail

De la modularité des architectures N tiers 1 Tiers Client 2 BD Tiers de données (Intranet) 4 Navigateur Tiers de présentation (Web serveurs) Fct Du client Équivalent 3 tiers 3 Application serveurs réplication Serveur mail Web service proxy Client Lourd Services WEB externes Autres couches logiques et physiques

Tiers Client Application avec laquelle l utilisateur interagit Contient les mécanismes de présentation Code responsable d afficher les données Code responsable de la communication avec les serveurs Un client léger ne contient pas de logique applicative Navigateur WEB : HTTP ou HTTPS + DHTLM, HTML, XML, WML, any-ml Un client lourd contient du code applicatif Application, Applet, ActiveX - IIOP / RMI, CORBA, Com etc. Application + WS - HTTP ou HTTPS + SOAP, XML, ebxml Tiers Client Navigateur Web service proxy Client Lourd

Tiers de présentation Permet la présentation des informations Dynamiques (après avoir contacté les autres tiers applicatifs) en fonction du type de client émettant une requête HTTP Dans le cas des clients de type navigateur WEB, les technologies utilisées sont par exemple : CGI (Programme( exécutables en Perl, C, C++ etc.) Pages interprétées - ASP (Active Server Pages) MSFT IIS - Java Servlets,, JSP (Java Server Pages) serveur WEB + Java container Autres (PHP etc.) Serveur Web Requête HTTP Contenu Documents statiques WEB container Modules d extension Autres tiers Scriptes CGI

Le tiers de Workflow Le tiers de workflow est une couche logique qui décrit que faire avec les données/informations fournies par l utilisateur La couche de workflow définit les règles qui régissent la saisie & d autres processus client Le tiers métier Cette couche contient les processus métiers (business logic) Les règles métier doivent maintenir l intégrité des données

Le tiers de données Contient les données nécessaires à l application fournies par des systèmes d information d entreprises qui peuvent être : Des bases de données - SQL2,SQL3 - Conception et administration = important! Des ERPs (entreprise ressource planing) Des legacy applications (système anciens sous IBM AS400 etc.) Le tiers d accès aux données Contient la logique et les mécanismes d accès aux données Ajouter, détruire, recherche, mettre à jour une donnée JDO, SQL/J, JDBC, ADO.NET,, Connecteur & protocoles propriétaires

Quelles sont les autres couches Il peut il y avoir autant de couches logiques que désiré en fonction des besoins Implantation physique? Performances? Importance grandissante de la phase d analyse et conception en fonction des besoins de l application Pourquoi créer des couches? Favoriser la réutilisation Gérer finement la sécurité Plus de tolérance aux fautes (+load balancing) Applications + scalables

Pour et contre des architectures en couches Architectures 1 tiers Simple Hautes performances Tout en 1 Pour contre Pas d accès distant Code spaghetti 2 tiers Conception claire & modulaire - de trafic réseau Séparation UI Business Logic Données et logique mélangées gestion du stockage 3 tiers N tiers Séparation UI Business Logic Stockage Stockage sûr & réplicable Accès conçurent aux données possible (transactions) Accès performant aux données Répartition de charges supporter différentes interfaces applications est + simple Réutilisation des composents : utiliser des protocoles/api communs Répartition de charges Mécanismes de réplications Sécurité rendre possible l achat de composent Besoin d un RDBMS DBA Apprendre SQL Correspondance objet difficile Coût - performant? Apprendre/choisir des API (Corba, COM etc.) Produits chers + complexe, + de fautes? Mise en place difficile Besoin de compétences techniques Complexe à gérer

Les architecture n tiers : couches logiques & couches physiques Logique de présentation Logique métier (règles métiers) Logique de connexion aux sources de données (accès aux données) Sources de données (Fichiers, BD, etc.)

Les architecture n tiers : couches logiques & couches physiques Client léger Serveur Portabilité, Maintenance, intégration d une nouvelle application (procédures stockées)? 1000 utilisateurs 1000 connexions 1000 processus 500 MB de RAM 10000 fichiers ouverts L OS est mort! Client lourd Serveur Serveur

Les architecture n tiers : couches logiques & couches physiques 1000 utilisateurs Tiers du milieu 50 connexions partagées 50 processus 25 MB de RAM 500 fichiers ouverts Cool! Tiers Client Tiers du milieu Tiers de données RDBMS ou autres Pb : différentes logiques dans un même code non séparation de la logique métier pb de maintenance Stopper le serveur pour Ajouter un nouveau type de client Ajouter une nouvelle source de donnée Tier du milieu = serveur WEB

Les architecture n tiers : couches logiques & couches physiques Zone démilitarisée (DMZ) Zone de confiance (trusted zone) Tiers Client HTTP port 80 Tiers du milieu HTTP port fixe Tiers de données Protocole propriétaire RDBMS ou autres La logique métier est exposée!

Les architecture n tiers : couches logiques & couches physiques Zone démilitarisée (DMZ) HTTP port 80 HTTP port aléatoire Zone de confiance (trusted zone) Tiers Client pres SRV App SRV Protocole propriétaire Tiers de données RDBMS ou autres

couches logiques HomePage.aspx Customer Presentation Layer GetCustomerInfos Customer DACustomer Business Logic Layer Nom, prénom DACustomer Data Layer Connexion SQL Address Book Contacts

couches logiques : ex dans le projet finance Data Business Logic Web Services Presentation Samic ADO.Net Integration Server SOAP COM Interop Internet Windows CE application (evb) Market Watch Server.Net Framework

couches logiques : ex dans le projet finance SQL Server 2000 Samic DB C# Components Samic Adapter.Net Framework Data BAMI Profile DB Data Bami Profile Access Adapter Misys Back Office Market Watch Server FIST activex Samic Component Business Bami Profile Logic Market Watch Web BankWS Services embedded Visual Basic Client W3F2 Embedded Application

couches logiques Internet Clients Presentation Web Servers Systèmes externes Mobile Devices HTTP SOAP Presentation Logic Application Servers Web Services Servers RMI/IIOP.NET/COM+ Remoting Interface Logic Routing Logic Business Logic Data Access Logic ADO.NET OLEDB JDBC Ressources Database MQ Directory

N tiers = architecture distribuée Répartir la logique sur plusieurs programmes, processus ou processeurs. Pourquoi la programmation distribuée? Utilisation de composants Parallélisme Ressource Loan Account Services du tiers du milieu = composants Manager Ledger Officer

architecture distribuées : historique Sockets X/Open Transport Interface RPC - Remote Procedure Calls DCE - Distributed Computing Environment COM/DCOM CORBA - Common Object Request Broker Architecture EJB Enterprise Java Beans ;.net remoting

Evolution des architectures N-tiers Coût de développement & de maintenance Architecture 2-Tier Architecture N-Tier Complexité de l application & durée de vie

Evolution des architectures N-tiers Besoin d un serveur applicatif = serveur WEB Supporter différentes BDs Supporter d anciennes application (legacy( apps) Code réutilisable = composants Connectivité Client Sécurité Management Gestion des Transactions Gestion de composants métiers Connectivité aux Sources de données Tiers Client Serveur d application Tiers de données Composants

Le tiers du milieu : rôle Gestion de composants fourni tous les services et outils pour gérer les composants du système et l implémentation de la «business logic»» comme - management de session - synchrone et asynchrone notification Tolérance de fautes, haute disponibilité Capacité de l application de résister à une possible panne sans point unique de panne. Définie les polices de récupération. 24-7 Passage à l'échelle Capacité pour le système d'accroître ses ressources matérielles pour supporter un nombre accru d utilisateur avec un temps de réponse constant Balance de charge Capacité d envoyer une requête a différents serveurs en fonction de la disponibilité des serveurs

Le tiers du milieu : rôle Ressources pooling Protège le tiers ressource en utilisant des groupes de connections partagées entre tous les clients Transaction Management Une transaction est une unité indivisible de travail comprenant plusieurs opérations, dont toutes ou aucune doivent être effectuées pour protéger l intégrité des données Assure les propriétés ACID des transactions (atomicité, consistance, isolation & durabilité) Console de management Unique point de management permettant de contrôle l ensemble du système incluant tous les serveurs Sécurité Authentification Autorisation

Type de serveurs : Serveurs d applications Serveur d applications - Environnement complet de développement coté serveur - Comprends toujours un serveur de composants - Serveurs avec états - Supporte «business logic»» décrite à l aide d objets, de règles et de composants - Exemples > Microsoft.net Enterprise Servers > J2EE Serveurs : IBM WebSphere,, BEA WebLogic, JBoss > ORB Corba Servers : Borland VisiBroker,, IONA ORBacus > Notez que les serveurs d applications Corba complet intègrent J2EE.

Architectures N-tiers Tiers de Présentation GUI Système du client (HTML, formulaire Windows) sur la machine cliente Tiers de Présentation logique WEB Logique serveur HTTP Ex : (WebForms+C # ou VB) ou (Servlets, JSPs : Java) pour produire : XML,HTML,WML Côté serveur Logique distribuée Connexion au serveur pour échange d information Tiers proxy ( soap, CORBA, RMI, COM+) Côté Client Interface cliente Application cliente développée Tiers métier (business tier) Règles & objets métier Manipulation des données pour les transformer en information (+ maintenance de l état) Tiers d accès aux données Interface avec les unités de stockage Interface BDs, Fichiers qui gère les I/O (généralement sans état maintenu) Tiers de données Stockage Langage interrogation, optimisation,ws

HTML, WML, XML, Soap Architectures N-tiers JDBC, SQL/J Vs ADO.Net, ADO,ODBC Autres Couches logiques Presentation tier MiddleWare services Business logic tier Data Access tier Data Access Déployé sur 1 ou N serveurs SQL2/ SQL3 Or ODMG «Component» approach (tight coupling) (CORBA,RMI ) vs (COM,DCOM ) «WebServices» approach (loose copling) SOAP/UDDI/WSDL SOAP, UDDI, WSDL Data source

Les serveurs d applicationd (vue logique) Eléments d un serveur d application WEB Web Service User/Provider Mainframe Backend Server Integration Layer Micro/Macro Services Virtual Machine Frontend Layer (Web Server) Legacy Workflow Engine Core Services (Calendar, Preferences, Transactions,...) Service Context (Who, Where, When, Why,...) Service Description (WSDL) Service Description, Discovery, Integration (UDDI) Web-based & -related Protocols (HTTP, SMTP,...) Clients

J2EE &.net : un niveau différent J2EE : un standard J2EE est une spécification avec de multipes implémentations J2EE = Ensemble de spécifications différents éditeurs logiciels, développeurs et vendeurs hardware (JCP - www.jcp.org) (Java Community Process) Basé sur le language Java - JRE interprète du bytecode Compatibility Test Suite, Blueprints Design Guidelines etc..net est un mélange de produits et de spécifications architecture de développement langage(s)/runtime

.NET.NET Foundation Services (Hailstorm) Passport, Calendar, Directory & Search, Notification & Messaging, Personalization, Web-Store/XML, Dynamic Delivery of Software & Services.NET Framework & Tools ASP.NET (Web Services, Web Forms, ASP.NET Application Services) Windows Forms (Controls, Drawing, Windows Application Services) Base Classes (ADO.NET, XML, Threading, IO,...) Common Language Runtime (Memory Management, Common Type System, Lifecycle Monitor).NET Servers SQL Server, Biztalk, Commerce, Exchange, Mobile Information, Host Integration, Application Center.NET Devices TabletPC, PocketPC,...

J2EE

J2EE = SQL pour Infrastructure applicative Distributed components & Web services Enterprise JavaBeans 2.0 & 1.1 (EJB) Java Messaging Service 1.0.1 (JMS) Transparent Web service bindings to EJB and JMS Remote Method Invocation (RMI/IIOP) Java Transaction API (JTA) Java Naming & Directory Inter. 1.2 (JNDI) Java Interface Definition Language (Java IDL) Web, HTML, and XML Servlets 2.2 & 2.3 Java Server Pages (JSP) 1.1 & 1.2 Database/legacy access Java Database Connection 2.0 (JDBC) Connector Architecture (J2EE CA) EJB Entity Beans

J2EE Conteneur web Conteneur EJB Servlet Java Page JSP EJB Les API : JDBC, JAVA MAIL, RMI etc.. Les API: JDBC, JAVA MAIL, RMI etc.. Serveur d applications J2EE Clients applicatifs DB

.NET Runtime Common Language Runtime (CLR) Tout langage compilé en MSIL +ieurs langages supportés Support de langages non OO C# VB.NET C++ Compiler MSIL + Metadata Loader/ Verifier JIT Perl Garbage Collection, Security, Multithreading,... Execution Managed Code

.NET Framework Code Source (C#, C++, VB.NET, J++, Cobol, Smalltalk, Eiffel, etc.) CLS/CTS «Managed Code» (MSIL).NET Framework Libraries.NET Compact Framework Libraries.NET CLR.NET CLR.NET CLR.NET CLR.NET CLR.NET CLR Windows 98/Me NT/2000/XP Linux Autre

Java Virtual Machine JVM interprète Java Byte Code. D autres langages peuvent être compilés en Java bytecode (e.g. Ada) Just-in in-time existe pour différents OSs Java Compiler CLASS- Files Classloader/ Verifier JIT Garbage Collection, Security Manager Call-in+Call-out, Multithreading,... Interpreter Hotspot Native Code

Modèle Java

J2SE 1.0: 212 classes 1.1: 504 classes 1.2: 1781 classes 1.3: 2130 classes 1.4: 2738 classes J2SE 1.4

(.NET) Tout est objet Types Value Types Reference Types Pointers Interfaces System Value Types User Value Types Self-describing Types Enumerations Classes Arrays Delegates Boxed Values User-Defined

System.Object Mère de toutes les classes public class Object { public virtual int GetHashCode(); public virtual bool Equals(); public virtual String ToString(); public static bool Equals(object a, object b); public static bool ReferenceEquals(object a, object b); public Type GetType(); protected object MemberWiseClone(); protected virtual Finalize() ; }

Object Model (Java) Types primitifs et objets Pas de boxing/unboxing automatique Types Primitive Types Reference Types Arrays Interfaces Classes

java.lang.object La mère de toutes les classes public class Object { public Object(); public boolean equals(object obj); public final Class getclass(); public int hashcode(); public final void notify(); public final void notifyall(); public String tostring(); public final void wait() throws InterruptedException; public final void wait(long timeout) throws InterruptedException; public final void wait(long timeout, int nanos) throws InterruptedException; protected Object clone() throws CloneNotSupportedException; protected void finalize() throws Throwable; }

en C# & Java: Hello World Example using System; namespace MyNameSpace { public class MyClass { public static void Main(String [] args) { Console.WriteLine( Hello, C#! ); } } } package MyPackage; public class MyClass { public static void main(string [] args) { System.out.println( Hello, Java! ); } }

Java // HelloWorld.java public class HelloWorld{ public static void main(string[] args){ for(int i= 1; i<= 100; i++) System.out.println("Hello!"); } }

C# Nom fichier peut être? nom classe Peut être omis si pas de paramètres // NAWAK.cs public class HelloWorld{ public static void Main(string[] args){ for(int i= 1; i<= 100; i++) System.Console.WriteLine("Hello!"); } } N classes publiques dans le même fichier int peut être traité comme un objet Main peut retourner le type int ou void

C# & Java Java C# import java.util.vector; public static int sum(vector v) { int sum = 0; for (int( j = 0; j < v.size(); j++) { Integer i = (Integer)v.elementAt(j( Integer)v.elementAt(j); ); sum = sum + i.intvalue(); } return sum; } using System.Collections; static int SumList(ArrayList thelist) ) { int sum = 0; foreach (int j in thelist) ) { sum = sum + j; } return sum; }

C# & Java Java C# try { throw new SampleException(); } catch (SampleException( ex) { } finally { } try { throw new SampleException(); } catch (SampleException( ex) { } finally { } catch est optionnel Pas de mot clé throws try { throw new SampleException(); } catch {} finally { }

Statements Exceptions en Java Les Exceptions doivent être déclarées dans la clause throws public int insert(int i) throws OverLimitException; { } Exceptions en.net Exceptions ne sont pas déclarées // Je mets un commentaire pour dire qu il y a une exception + loin public int insert(int i) { }

Modèle Objet Les types de bases ne peuvent pas être utilisés comme des objets en Java Integer i_ref = new Integer(7); List l =... l.add( i_ref ); i_ref.intvalue(); C# : boxing & unboxing i 123 int i = 123; object o = i; int j = (int)o( int)o; Heap o j 123 123 System.Int32 Stack

Données dynamiques en C int *pint; Func1(int intarg) { } int IntLocal; IntLocal = IntArg; main() { } pint = malloc(sizeof(int)); Func1(1); // global pointer var // functions lifetime // lives until free() Memory Stack (Fragments During Execution) Heap Static Data Code FFFF 0000

Données dynamiques en C# Class Class1 { } public static int IntStatic = 1; public int IntInstance; public Method1(int intarg) { } int IntLocal; intlocal = intarg; Class1 NewClass1 = new Class1; // create object Class1.Method1(1); // global var // object s lifetime // method s lifetime JIT Cache GC Pools Metadata Map Memory Stack Heap Static Data Code FFFF 0000

/*** JAVA ***/ class A {} interface I {} interface J {} Implémentation & Héritage class B extends A implements I, J {} /*** C# ***/ class A {} interface I {} interface J {} class B : A, I, J {}

.NET-TypesTypes non disponibles en Java Delegates & Events: JeRéagis QQchoseSePasse JEnvoieUnEvt QQchoseSePasse class JEnvoieUnEvt{ JEcouteEtRéagisAuxEvts... public event FctADeclancherQuandQQchoseSePasse QQchoseSePasse; public delegate void FctADeclancherQuandQQchoseSePasse (int param);... } } Je m abonne (+=) class JEcouteEtRéagisAuxEvts{... JEnvoieUnEvt Sender; // + création etc.... Sender. QQchoseSePasse += new FctADeclancherQuandQQchoseSePasse (this.jeréagis); Public void JeRéagis (int x){.} }

.NET-TypesTypes non disponibles en Java Enumerations (value type): enum Color : byte { RED = 1, BLUE = 2, GREEN = 3 }; Jagged & unjagged Arrays: Structs (value types): Structs = sealed Pas d héritage struct Point { int x, y;... } Point p = new Point(10, 20); int[ ]array1=new int[ ]{1,2,3}; int[ ][ ]array3=new int[3][ ]; array3[0]=new int[ ]{1,2,3,4}; array3[1]=new int[ ]{5,6,7,8,9}; array3[2]=new int[ ]{10,11}; point 10 20 20 point 10

C# : gestion des caractères spéciaux Eviter la protection ('\n \t \\'' ) via «@» : string texte01 = "c'est pas toujours très\nlisible nlisible\t\tdestdes textes formatés\ncomme ça"; string texte02 = @"c'est pas toujours très lisible. des textes formatés comme ça";

Les mots clés C# using Main Console.WriteLine Console.Write string System.Object is public private internal* sealed static this base unobjet as UneClasse ToString()... Java import main System.out.println System.out.print String java.lang.object instanceof public private protected* final static this super (UneClasse)unObjet cast tostring()...

Points en commun & Differences points en commun : Interfaces = «abstract classes» Classe = héritage simple Interface = héritage multiple Variables initialisées par défaut Concept des Namespaces (Java-Package &.NET. NET- Namespace) Même visibilité des attributs (public, private,,...) Différences.NET : pas de différence entre types primitifs & classes. Multiple langages supportés en.net Java : toute méthode = implicitement virtuel..net : explicite (virtual( virtual, override,, new). Java : packages = répertoire, pas.net

Metainformation Java &.NET ont des APIs réflection Lire & instancier des classes.net permet l annotation du code (classes, members, operations) ) avec la notion d Attributes

Using an Attribute [AuthorIs( Michael )] class MyClass {... }.NET Exemples Il y a des attibuts par défaut (WebService( WebService, WebMethod,...) Définir un Attribut : [AttributeUsage(AttributeTargets.All)] public class AuthorIsAttribute : Attribute { private string m_name; public AuthorIsAttribute(string name) { m_name = name;} }

.NET Exemples Utiliser l information de type using System; using System.Reflection; namespace ComponentClient { class Client { static void Main(string[] args) { Assembly a = Assembly.LoadFrom("Component.dll"); Type [] alltypes = a.gettypes(); Type t = alltypes[0]; object o = Activator.CreateInstance(t); MethodInfo mi = t.getmethod("algorithm"); double d = (double) mi.invoke(o, new object[]{21.0}); } } }

Java Example Utiliser l information de type : Note : packages <> assemblies!! import java.lang.reflect.*; try { Class c = Class.forName( MyPrintComponent ); Object o = c.newinstance(); Method m = c.getmethod( print, new Class[]{ String.class }); m.invoke(o, new Object[]{ Hallo, Java! }); } catch (Exception e) { }

Points en commun & Différences Points en commun : Les APIs se ressemblent Différences:.NET : meta information avec les attributes La réflection en Java est parfois + compliquée (à cause des classes et types primitifs).net permet la création de nouvelle classe «at runtime» & de les instancier à l intérieur d un assembly.

Statements Les 2 PFs ont les mêmes instructions de programmation (statements( statements) Différences: string name = address.name; switch (name) { case Maier : Console.WriteLine( Nice to meet you, Hans! ); break; case Mueller, case Huber : Console.WriteLine( You owe me some money! ); break; default: Console.WriteLine( I don t know you ); break; }

Statements Différences: Iterators en.net: foreach (Elemi en MyContainer) { Console.WriteLine(i); }... class MyContainer : IEnumerable, IEnumerator { public IEnumerator GetEnumerator() { return (IEnumerator)this; } public void Reset() {... } public bool MoveNext() {... } public object Current { get {... } } }

Différences: Iterators en Java: Statements for (Iterator i = MyContainer.iterator(); i.hasnext();) dosomething(i.next());... class MyContainer implements Iterator { public boolean hasnext() { } public Object next() {...} public void remove() {...} public Iterator iterator() { return this; } }

Statements Différences: Propriétés en.net où Java utilisent des conventions de codage Class MyClass {... public double x { set { if (value < 0) throw new ArgumentException ( < 0 ); m_x = value; } get { return m_x; } }... // User: MyClass m = new MyClass(); m.x = 22;

Statements Différences:.NET supporte des Indexers,, pas Java object[17] = 22; // en class: Int [] m_a; public double this[int pos] { get { return m_a[pos]; } set { m_a[pos] = value; } } Les Indexers marchent aussi avec les non entiers comme les Strings

Statements Différences:.NET supports la surcharge des opérateurs public static Point operator+(point op1, Point op2) { return new Point(op1.x+op2.x,op1.y+op2.y); }... Point p = new Point(1,2) + new Point(2,3);

Statements Différences:.NET permet le passage par référence des arguments de méthodes class Test { public void Print(int i) { Console.WriteLine(i); } public void Inc(ref int i) { i++; } public int SetInitial(out int i) { i = 42; }... } Test t =...; int i; t.setinitial(out i); t.inc(ref i); t.print();

Pas de grandes différences Classes de bases.net Java GUI Windows.Forms Web.Forms SWING, AWT Communication System.Net: Connection, HttpWebRequest,... Java.net: Sockets, URL,... Container System.Collections: ArrayList, BitArray, Maps, Queue, List, Stack java.util: Lists, Maps, Sets, Trees, Vectors

Les threads C# void P() {... thread actions... } Thread t = new Thread(new ThreadStart(P)); Java class MyThread extends Thread { public void run() {... thread actions... } } Thread t = new MyThread();

Synchronisation de méthodes C# Java public void WithdrawAmount(int num) { lock(this) { } } if(num < this.amount) this.amount -= num; public void withdrawamount(int num) { synchronized(this) { } } if(num < this.amount) this.amount -= num;

points en commun & Différences points en commun : Threading quasi similaire Les 2 ont la notion de gestion & synchronisation Différences: Synchronisation Java mieux intégrée dans le langage Java = meilleure synchronisation & communication inter-thread thread (wait, notify,,...).

Packaging Java Fichier.class pour chaque classe. Regroupement de ces fichiers (.jar)..class et.jar doivent être dans le «classpath»..net Regroupement en Assemblies (.EXE,.DLL) Gestion des versions - Le CLR s occupe de «loader» le bon assembly en fonction de la version. - Un même processus peut même utiliser deux versions différentes d un même assembly,, en même temps - Élimine les problèmes de compatibilité entre différentes versions d une même DLL. GAC: Global Assembly Cache - Endroit où sont stockés les assemblies. - Géré par le framework.

Assemblies en.net Assembly = ensembles de types name version Custom Attributes Sharedname Hash Manifest Files Referenced Assemblies Product Information Types Security Type 1 IL-Code Type 2 IL-Code Type 3 IL-Code Module 1 Metadata Resources

Assemblies en.net «Private Assemblies» pour un seul programme «Shared Assemblies» tockées dans un cache commun & utilisable par plusieurs applications. Signées par une clé Versionnées!!

Java JAR files.jar files sont l équivalent des.net s assemblies «shared» ou «private» Peuvent être signées Ils contiennent des types ressources (metadata dans un fichier manifest)?. Pas de notion de versioning!

Points en commun & Différences points en commun : Assemblies & JAR = composants de déploiement Différences: Support de la version en.net (side( side-by-side exécution)

Composant serveurs en.net Notion de composants en EJB/COM+ Pour utiliser des services du serveur d application comme la synchronisation,les transactions, ou le pooling,, les services COM+ peuvent être utilisés COM+-Interop offrent ces fonctionnalités

Gestion des composants : managed / unmanaged.net propose le même ensemble de services sous l'appellation de ServicedComponent. Le conteneur utilisé dans le Framework est COM+ COM+ fonctionne dans un environnement non managé avec une gestion de type différente de celle de.net (Common Type System) Dans J2EE les transactions sont gérées en Java à l'aide des API JTA/JTS et l'ensemble des composants s'exécutent dans un seul et même environnement managé.

Java Component Models Client Components & Server Components JavaBeans = Components Clients classes Java normales suivant certaines conventions public class MyJavaBean { private int color; public void setcolor(int v) { color = v; } public int getcolor() { return color; } // a lot of more... } // BeanInfo class not shown here!

Server Components en Java Enterprise JavaBeans (EJBs)) résident toujours dans un Container qui offrent les fonctionnalités JNDI 1) lookup home Naming Service Deployment Descriptor 2) create bean 2 ) find bean Client Remote Bean Home Interface EJB Home new 4 EJB Context EJB Jar 4) remove 3) Use bean Remote Bean Interface EJB Object ejbcreate ejb... EnterpriseBean bean-methods Bean Instance EJB Run-time Application Server (Container)

Server Components en Java 4 Types de Beans Stateless Session-Beans (Service Components) Stateful Session Beans (Session Components) Entity-Beans (Entity Components) Message-Driven Beans (asynch.. Service Components) 1 bean est (théoriquement) portable de container à container (Application Servers) ) des différents éditeurs.

Points en commun & Différences points en commun : Les «Server Components» sont disponibles (Assemblies + COM+, EJB). Interopérabilité avec les anciens composants en.net en utilisant COM+, en Java en utilisant CORBA) Différences: Les EJBs sont + matures Des APIs existent pour la connexion aux legacy systems (Java Connector API)

Accès BD en.net : ADO.net Presentation Tier Windows Forms MyApp.Exe DataSet Web Forms IE DataSet XML Internet Intranet Business Tier Data Object (Class) DataSet Data Adapter Data Adapter Data Tier Business to Business (BizTalk, for example)

Accès BD en.net : ADO.net Controls, Designers, Code-gen gen,, etc XSL/T, X-Path, X etc DataSet Dual View XmlData- Document DataAdapter DataReader XmlReader Command Connection.NET Data Provider Travail sans conexion possible

Accès BD en.net : ADO.net DataSet DataTable DataColumn DataTable DataRow Relations XML Schema Constraints

Exemple.NET using System; using System.Data; using System.Data.SqlClient; string myconnection = server=myserver;uid=sa;pwd=;database=stocktickerdb ; string mycommand = SELECT * from StockTable ; SqlDataSetCommand datasetcommand = new SqlDataSetCommand (mycommand, myconnection); DataSet mydataset = new DataSet(); datasetcommand.filldataset(mydataset, StockTable ); DataTable mytable =ds.tables[ StockTable ]; foreach (DataRow row en mytable.rows) { Console.WriteLine( Value of {0} is {1}, row[ LongName ], row[ Value ]); }

ADO.NET ADO.NET est basé sur XML (XML Infoset) DataSet créé dynamiquement suivant «XML schema» pour stocker les données Les données relationnelle et les données XML sont traitée de la même façon! ADO.NET peut travailler offline une fois que les données sont chargées La MAJ est rendue automatique par les DataSets

L architecture JDBC Application JDBC Driver Le code Java appelle les libraries JDBC JDBC charge un driver Driver parle parle avec les différentes bases de données +ieurs drivers sont possibles -> > + d une BD Idéal : la BD peut être changée sans toucher au code!

Accès aux sources de données en Java

Accès aux sources de données en Java Java utilise JDBC pour accéder aux données relationnelles Application Statement Resultset Prepared Statement Connection Driver Manager Callable Statement JDBC/ ODBC Bridge ODBC Driver ODBC DB

Exemple Java import java.sql.*; // without error hadnling: Connection con=drivermanager.getconnection( jdbc:odbc:stocks,, ); Statement stmt = con.createstatement(); ResultSet rs = stmt.executequery( SELECT * from stocks ); while (rs.next()) { } System.out.println(rs.getString( COMPANYNAME )); rs.close(); stmt.close(); con.close();

Accès BD en Java Il y a d autres APIs possibles : «Embedded SQL» dans les formulaires SQLJ (JDBC utilisé en interne) APIs ODBMS propriétaires API JDO pour offrir la persistance pour les objets Java XML est géré différemment «Java Connector API» offre l accès aux legacy systems «orientés connexion» (ex: SAP R3)

Points en commun & Différences points en commun : Découplage entre le modèle concret de données et le modèle de programmation (DataSets( & ResultSets) Différences: ADO.NET est basé sur XML, JDBC est + «relationnel» JDBC = orienté connexion, ADO.NET = connecté ou déconnecté.net DataSets In-Memory Memory-Database-Cache.

XML &.NET.NET = XML-centric Web Services (SOAP) Fichiers de Configuration Datasets pour les accès aux BD (ADO.NET) Note : de nombreuses caractéristiques de.net sont basées sur l XML infoset («XML semantics»)

XML &.NET The System.Xml Namespace = classes de gestion du XML DOM : XmlNode & fils XPath & XslTransform XmlTextReader & XmlTextWriter similaire à SAX en ce sens qu ils sont tous deux «stream-based»

+ieurs outils standards : DOM, SAX Xerces/Xalan, JDOM JAX{P,M,B,R,RPC} Castor XML & Java Mais les librairies Java s n ont pas été conçues avec XML comme base (Java est trop vieux ) JAXP (Java API 4 XML Parsing) ) supporte DOM & SAX. En cours de développement : JAXM (Java API pour le XML Messaging) JAXB (Java API pour le XML Data Binding) JAXR (Java API pour le XML Registries) JAX/RPC (Java API pour le XML based RPC)

XML & Java

Remoting en.net Application Domain A Application Domain B Client Serveur Transparent Proxy Real Proxy Envoy Sinks Channels Formatters Network Object Context Sinks Server Context Sinks Channels Formatters

Remoting en.net.net Remoting propose le formatage et le transport des appels distants actuellement TCP & HTTP transport Format binaire & SOAP Les Contextes sont automatiquement propagés Les options de «lifecycle management» sont très simples (comparé à EJB & CORBA) Singleton (1 objet pour tous les appels) SingleCall (1 nouvelle instance pour chaque appel)

Remoting en.net Les Objets peuvent être marshallés par valeur (Serialisés) Les invocations asynchrones sont facilement possibles sans toucher au serveur

Points en commun & Différences points en commun : Le concept Différences : Les appels asynchrones ne sont pas facilement possibles en Java

Remoting en Java +ieurs possibilités : RMI/CORBA RMI utilise JRMP ou IIOP comme protocole de transport Client Server Stub Stub/Skeleton-Layer Skeleton Remote Reference Manager Transport Layer

IIS & ISAPI ASP.NET request *.aspx *.asmx *.ashx HTTP Request ISAPI Extension Manager ASPNET_ISAPI.DLL ASP.NET ISAPI extension named pipes ASP.NET CLR Object INETINFO.EXE IIS worker process ASPNET_WP.EXE ASP.NET worker process aspnet_state.exe (ASP.NET session cprocess) COM+ runtime Win2k Server COM+ Context

ASP.net Presentation Layer Response Business Logic Layer.NET CLR 1. Request IIS & ASP.NET ASPX Code Behind Renders Self XML Request 9. Response ASPX Page 8. Returns WS SOAP Web Service ASMX Code 4. Execute Class Business Object Class VB.NET ASP.NET 2. Invokes Web Service Proxy 3. Calls Web Service ASP.NET CLR 5. Invokes Enterprise service 6. Proxy Calls COM+ Object INETINFO.EXE IIS worker process ASPNET_WP.EXE ASP.NET worker process COM+ runtime Win2k Server

ASP.net Button Button code... List Text List code... Text code... Browser ASP.NET Event handlers

A simple login screen: ASP.NET Example

ASP.NET <%@ Page language="c#" Codebehind="WebForm1.aspx.cs" AutoEventWireup="false" Inherits="LoginPage.WebForm1" %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" > <HTML> <body> <form id="form1" method="post" runat="server"> <asp:label id="titlelabel" runat="server">please specify your name & password</asp:label> <br> <asp:label id="loginlabel" runat="server">login</asp:label> <br> <asp:textbox id="logintext" runat="server"></asp:textbox> <asp:requiredfieldvalidator id="requiredfieldvalidator" runat="server" ErrorMessage="You need to specify your name" ControlToValidate="LoginText"></asp:RequiredFieldValidator> <br> <asp:label id="passwordlabel" runat="server">password</asp:label> <br> <asp:textbox id="passwordtext" runat="server" TextMode="Password"></asp:TextBox> <br> <asp:button id="enterbutton" runat="server" Text="Open the entrance" ToolTip="Press this after you have specified login & password"></asp:button> <br> <asp:label id="messagetext" runat="server"></asp:label> </form> </body> </HTML>

namespace LoginPage { ASP.NET public class WebForm1 : System.Web.UI.Page { protected TextBox PasswordText, LoginText; protected Button EnterButton; protected Label MessageLabel; private void InitializeComponent() { this.enterbutton.click += new System.EventHandler(this.EnterButton_Click); this.load += new System.EventH&ler(this.Page_Load); } private void EnterButton_Click(object sender, System.EventArgs e) { if (!(LoginText.Text.Equals("aladdin") && PasswordText.Text.Equals("sesam"))) { MessageLabel.Text = " Wrong name or password!"; } else { Session["user"] = "aladdin"; Response.Redirect("UserArea.aspx"); } } } }

Java Server Pages & Servlets Java permet également le «server-side side scripting» Les JSPs sont basés sur les Servlets Client (1) get a.jsp (2) process (5) HTTP file Web Server JSP (3) gen. Servlet Servlet Impl. Other Components (4) result Servlet Database JVM

Exemple Java

Exemple Bean & JSP : Java Example // Datei MyPerson.java package MyPackage; import java.lang.*; public class MyPerson { public String getfirstname() { return "Michael"; } public String getlastname() { return "Stal"; } } // Datei MyTest.jsp: <HTML> <BODY> <jsp:usebean id="person" scope="session" class="mypackage.myperson"/> Your name is: <br> <jsp:getproperty name="person" property="firstname"/> <br> <jsp:getproperty name="person" property="lastname"/> </BODY> </HTML>

9iAS et J2EE internet WebCache Mod_file Mod_sql http listener (Apache) Mod_oc4j Mod_sso LDAP server AJP Static HTML Files< Dynamic HTML files Servlet Servlet Servlet EJB EJBEJB Stored Procedures OC4J OC4J

Web Services dans 9iAS Webservices Servlet Servlet Stored Proc. Servlet Java Class Stored Proc. Web service Http OC4J Integration Hub Adapter EJB Web Service EJB JMS Legacy Application 9iAS OC4J

Points en commun & Différences points en commun : Pages = près compilées pour accélérer l accès Même syntaxe & concepts ASP.NET propose de composant graphiques avec les Webcontrols,, Java a lestaglibs. Différences: Les différents langages de.net peuvent être utilisés pour le scripting ASP.NET Servlets/JSP sont disponibles sur un grand nombre de serveurs différents Beaucoup d implémentations et d outils en Java

Web Services en.net.net : manière intégrée de créer des WS namespace WebService1 { public class Service1 : System.Web.Services.WebService { // lot of stuff omitted [WebMethod] public double DM_to_Euro(double value) { return value / 1.95583; } } } [WebMethod] public double Euro_to_DM(double value) { return value * 1.95583; }

Web Services en.net Créer un WS est très simple : (l ex est simplifié ) localhost.service1 s1 = new localhost.service1(); double result = s1.euro_to_dm(200); Webservices = un moyen de faire du «remoting» Mais avec.net : Pas de compatibilité ebxml Seulement implémenté sur MS server

Web Services en Java Sun ONE fournit une API Web Service pour Java compatible ebxml +ieurs solutions propriétaires : SOAP toolkits: - Apache SOAP - IBM Web Services Toolkit - GLUE Intégrées aux serveurs d application - Silverstream - IONA - Weblogic -... Sun travaille à des APIs standards JAXM

Points en commun & Différences points en commun :.NET & Java essaient d être compatibles aux standards (SOAP, WSDL, UDDI). La gestion est similaire : générateurs de WSDL qui créaient des proxies Différences: Java a différentes solutions où.net n en a qu une Actuellement les standards sont interprétés différemment, ce qui rend l Interop Java-.NET limitée. Mais il y a des chances que cela change.

Enterprise APIs Naming: JNDI en Java (interface à CORBANaming,, LDAP,...) Active Directory en.net (Windows) Middleware orientés messages : JMS en Java JAXM à l horizon (XML based messaging).net peut utiliser MSMQ, & le remoting peut être utilisé de manière asynchrone

Legacy-Integration.NET utilise le Microsoft Host Integration Server. Java utilise la Connector API Java offre une solution + simple. Les Connectors sont rapidement implémentés...

De l Interopérabilité Java offre un accès à C/C++ via JNI (Java Native Interface). Solution complexe de call-in in, call-out out..net offre la primitive PInvoke: class PInvokeTest { [DllImport("user32.dll")] static extern int MessageBoxA(int hwnd, string m, string c, int t); static void Main(string[] args) { MessageBoxA(0, "Hello DLL", "My Window", 0); } }

COM /.net Common Language Runtime COM Server Reference Counted Runtime Callable Wrapper Object Client Traced Reference

De l Interopérabilité En.NET l interopérabilité est possibles entre COM & COM+ Services. Java offre une interopérabilité CORBA En.NET l interop entre les langages.net est automatique et facile Assemblies,, class libraries Certains langages doivent être un petit peu adaptés (ex Managed C++ n a pas d héritage multiple)

Des variantes de Java Offre Java J2SE (Java 2 Platform Standard Edition) J2EE (Java 2 Platform Enterprise Edition) J2ME (Java 2 Platform Micro Edition) JavaCard

J2ME 1. Foundation Profile 2 Profiles Configuration: Connected Device Configuration (CDC) API de base + Machine Virtuelle CVM. Ensemble d APIs supplémentaires. Cible: Télévision digitale, télé-avertisseurs, PDA, Cellulaires-Web. Ressource: 1024K minimum ROM, 512K minimum RAM, Connexion réseau, Pas de GUI. 2. Mobile Information Device Profile (MIDP) Configuration: Connected Limited Device Configuration (CLDC) Api de base + Machine virtuelle KVM. Ensemble d APIs supplémentaires. Cible: Cellulaires, PDA. Ressource: Aussi peut que 160K au total (RAM + ROM). + Le J2ME Wireless Toolkit pour développer et tester des applications J2ME.

Vision MSFT Today Client Application Embedded Visual Tools evb and evc++ Visual Studio &.NET Compact Framework Web Application Device-specific Active Server Pages Visual Studio & Mobile Internet Toolkit

Vision MSFT Visual Studio.NET + Smart Device Extensions Tool SDKs evc Pocket PC + PPC Phone Edition Microsoft Smartphone Other Windows CE Devices.NET Compact Framework.NET Framework Notebook PCs Tablet PCs SDKs OS Windows CE Windows XP OS

Smart Client Technology Choices Native ou Managed evc and evb evb native evc Managed.NET CF (VB.NET, C# etc.) evc Time

Vision MSFT : accès aux données Smart client Browse Mobile Browser.NET Compact Framework 4. ADO.NET Local Data SQL Server CE Windows CE WAP, HTML etc. 1. XML Web services 2. Synchronization (http) ASP.NET, Mobile Controls Presentation Layer XML Web Services 3. Direct SQL Server access SQL Server Windows Server

Projet W3H Presentation Layer Business Logic Layer Data Access Layer Remote Data Source Dynamic pages Web Services I/F Medasys data access Component Business object Vidal data access Component

.net Client Browser Presentation Layer Business Logic Layer Data Access Layer Remote Data Source HTTP COM+ SOAPWebService I/F (WebService Proxy) ASP.NET ASP.NET (WebServices) (MobileWebForm) SOAP ASMX class ASPX class Business Class DCOM HTML, WML, CHTML,... COM+ (ADO.NET) ADO OleDBcompatible DB

.net Data Presentation Layer Business Logic Layer Remote Data Source Access Layer Response.NET CLR.NET CLR & Enterprise Service.NET Server / DataBase Request IIS & ASP.NET 1. Request 9. Response 4. Execute Class ADO.NET DataAdapter Net8 Stored Proc ASPX Code Behind Renders Self ASPX Page WS SOAP WebServic es I/F Business Object WebServi ce Proxy TCP WS SOAP Web Service I/F XML 8. Returns ASMX Code Class VB.NET 7. Access Data 2. Invokes Web Service Proxy 3. Calls Web Service 5. Invokes Enterprise service Proxy 6. Calls COM+ Object Data Access object C# Class Extend ServiceComponent

Data Access Layer COM+ is deeply integrated into the CLR All COM+ services made available to CLR COM+ types defined within the EnterpriseServices namespace COM+ = COM (object-oriented oriented system) +MTS +Services (Queued MTS (Transaction Server) Component,COM+ + event).net CLR & Enterprise Service 7. Access Data Data Access Layer Data Access object C# Class Extend ServiceComponent ASP.NET CLR ASPNET_WP.EXE ASP.NET worker process COM+ runtime (DLLHost.EXE) Win2k Server ADO.NET DataAdapter WebService Proxy

Exemple.net : le pooling.net CLR Business Logic Layer WebServices I/F ASMX Code 4. Execute Class 5. Invokes Business Object Class VB.NET Client creates "new" instance Instance is served from pool.net CLR & Enterprise Service Data Access Layer 7. Access Data Data Access object C# Class Extend ServiceComponent ADO.NET DataAdapter WebServi ce Proxy Enterprise service Proxy 6. Calls COM+ Object COM+ manages x active instances COM+ runtime (DLLHost.EXE)

Vue globale INETINFO.EXE IIS worker process Presentation Layer 1. Request ASP.NET Renders Self ASPX Code Behind XML 2. Invokes Response Request 9. Response ASPX Page 8. Returns WS SOAP Web Service Proxy 3. Calls Web Service ASP.NET Business Logic Layer Web Services I/F ASMX Code.NET CLR 5. Invokes 4. Execute Class Business Object Class VB.NET Enterprise service Proxy 6. Calls COM+ Object Data Access Layer.NET CLR & Enterprise Service 7. Access Data Data Access object C# Class Extend ServiceComponent ADO.NET DataAdapter Web Service Proxy TCP Net8 WS SOAP Remote Data Source.NET Server / DataBase Stored Proc Web Service I/F CLR ASPNET_WP.EXE (ASP.NET worker process) COM+ runtime (DLLHost.EXE) Win2k Server

J2EE Client Browser Presentation Layer Business Logic Layer Data Access Layer Remote Data Source HTTP EJB SOAPWebService I/F (WebService Proxy) HTML, WML, CHTML,... Servlets Java Server Pages SOAP Web Services (Java Class) Business Class RMI / IIOP EJB (JDBC) Net8 JDBC compatible DB

J2EE Presentation Business Logic Data Access Remote Data Source Response OC4J OC4J Request Apache & OC4J 9. Response 4. Execute Class JDBC Net8 Stored Proc 1. Request 8. Forward JSP 2. Invoke JSP (Taglibs) 3. Calls Web Service WS SOAP Web Service I/F Java Class Business Object Java Class RMI 7. Access Data WebServi ce Proxy TCP WS SOAP WebS ervice I/F WebServi ce Proxy 5. Invokes EJB Home/Int erface 6. Calls EJB RMI EJB Data Access

Oracle 9ias OC4J Presentation Response OC4J Business Logic OC4J Data Access Remote Data Source.NET Server / DataBase 1. Request JSP 8. Forward 2. Invoke Request 9. Response JSP (Taglibs) 3. Calls Web Service WebService Proxy WS SOAP Web Service I/F Java Class 4. Execute Class 5. Invokes Business Object Java Class EJB Home/Interface 6. Calls EJB RMI RMI 7. Access Data EJB Data Access JDBC WebService Proxy TCP Net8 WS SOAP Stored Proc Web Service I/F 9IAS WE 9IAS Any OS

Interop Presentation Layer : DotNet Business Logic & Data Access : J2EE Response Web Service: String array serialized in XML WS Proxy : deserialized XML Stream on String Array Presentation Business Logic Data Access ASPX Code Behind DataSet Object String WebService Array Proxy Object WS SOAP String Array Web Service I/F

Interop Presentation Layer : J2EE Business Logic & Data Access : DotNet Response Web Service: DataSet serialized in XML WS Proxy : deserialized XML Stream on XmlElement Presentation Business Logic Data Access JSP Vector Object XmlElement Object WebService Proxy WS SOAP DataSet Serialize Web Service I/F

Résumé J# C# VB.NET Managed C++ Java MSIL Byte Codes CLR JRE / JVM BCL Windows OS.NET Core Lib Mac Win Unix Linux Java

Résumé Browser Device HTML, XML, SOAP HTTP IIS ADO.NET ASP.NET or ISAPI Web Service MSMQ DCOM Security Transactions Concurrency Managed Object Managed Object ADO.NET Data Context.NET Framework Windows Browser Device HTML, XML HTTP HTTP Server JDBC Servlet or JSP RMI/IIOP Security Transactions Concurrency HOME REMOTE Entity Bean Session Bean JDBC Data Containers JVM Context EJB Server App Server Any OS

Exemple d architectures J2EE with JSP/Servlets Servlets.NET with ASP.NET Presentation JSP/Servlets JavaBeans (Struts & Tomcat) Runs on most major web servers ASP.NET IIS Web Forms Server Controls Code-Behind Business Logic EJBs (JBoss) J2EE JDBC CLR C# Assembly ADO.NET Use COM+ via Serviced Components Data Hypersonic SQL Support for most databases via Type 4 drivers SQL Server 2000 Stored Procedures

Downhill Bikes J2EE Presentation Business Logic & Messaging Fabric Data Integration & Persistence Web Server & Servlet Engine 1. Request Response Action Servlet Request 11. Forward 13. Response 12. State? JSP (Taglibs) EJB Container 7. Execute Biz Method 8a. Read Data Business Service Façade (SLSB) 8b. CRUD Data RMI EJB Container 9b. Get/Set Remove Data Access Object 9a. Query <<uses>> Resources Directory Database <<uses>> JMS XML Action to Form & Forward Mappings 4. Dispatch 2. Fill State 3. Validate <<uses>> Action Object 5. Execute 10. Fill State Action Form <<uses>> <<creates>> Value Object Entity Bean Data Connection Factory Connection Pool Key Test Client Test Biz Methods Use Case Object 6. Execute Biz Method <<uses>> Value Object RMI M V C P Model Pattern View Pattern Controller Pattern Other Pattern

Downhill Bikes -.NET Presentation Business Logic & Messaging Fabric Data Integration & Persistence Response.NET & Windows ADO.NET Request IIS & ASP.NET 1. Request ASPX Code Behind 8. Response Renders Self ASPX Page WS SOAP Any Other Use Case Facade Business Service WS Facade 4. Execute Use Case Use Case ADO DataAdapter 5. Accesses Data <<uses>> TCP SQL DataProvider 6. Query MS SQL 2. Invokes XML DataSet WS Façade Proxy 7. Returns 3. Calls Web Service Use Cases Facades <<generates>> <<creates>> XML Schema.XSD SQL Connection App. Config. Web.config Key XML DataSet M Model Pattern V View Pattern C Controller Pattern P Other Pattern

Architecture.NET Presentation Eléments de programmation 1. User Interface (WEB PAGE) Exemple: OrderProcess.aspx Separation de la Presentation UI & Presentation Logic en 2 fichiers 2. WEB PAGE CODE ( Code Behind ) OrderProcess.aspx.cs Business Logic 3. BUSINESS CLASS (Order Object) Order.cs Data Tier 4. Stored Procedures upordersadd database ADO.NET

Architecture J2EE Eléments de programmation 1. User Interface (HTML with JSP code) Exemple: OrderProcess.jsp Separation du Code Presentation & Busines 2. User Interface Handling Tier (Servlet Code) OrderProcServlet.java 3. BUSINESS LOGIC OBJECT (EJB Session Bean) OrderSession.Java RMI-over -iiop EJB Application Server 4. BUSINESS DATA OBJECT (EJB ENTITY BEAN ) database OrderEntityEJB.java RMI-over -iiop JDBC/ ODBC

Architecture J2EE Presentation Logic Data Logic <<HTML>> <<HTML>> <<build>> <<JSP>> <<JSP>> <<Entity EJB>> <<Entity EJB>> <<link>> <<forward>> DB Server <<Servlet>> <<Servlet>> <<Session EJB>> <<Session EJB>> Business Logic

Modèle typique en.net Presentation Business Logic.Aspx.aspx.cs Business Object Classes Server 1 database Stored Procedures RDBMS Engine

Modèle typique en.net Load Balancer Presentation Business Logic Presentation Business Logic.NET Managed Components Server 1 Server 2 database State Server

Modèle typique en J2EE Server A Presentation JSP SERVLETS Server 1 Business Logic SESSION BEANS database ENTITY BEANS DATABASES

Modèle typique en J2EE NLB Presentation Presentation JSP SERVLETS Ejb Application Servers Server 1 Server 2 Business Logic Business Logic SESSION BEANS Database PROXY Database PROXY ENTITY BEANS database RDBMS Engine

.NET &/ou Java?.NET est un produit, J2EE est une spécification Tous les 2 sont fortement centrés sur le WEB Pour de gros systèmes transactionnels, J2EE est + mature, mieux adapté Les notions «Java est indépendant des PF» &.NET est «indépendant des langages» sont à prendre avec précaution: L ECMA travaille à la standardisation de C# et de certaines parties de.net D autres langages peuvent être compilés pour la JVM

.NET &/ou Java? L indépendance des langages.net n est pas gratuite et n est pas totalement transparente. #pragma once using namespace System; //.NET mit C++ namespace CPPBase { public gc class CPPBaseClass { public: virtual System::String gc* Echo(System::String gc *s); }; } System::String gc * CPPBase::CPPBaseClass::Echo(System::String gc *s) { return s; } Dans un projet mieux vaut utiliser un seul langage

.NET &/ou Java? Windows Applications.NET + que Java (IBMs( SWT à suivre?) Utiliser Java quand l indépendance de PF est nécessaire Java est plus mature (?) Il y a Java pour.net (J #) Mais la syntaxe n est pas le problème Web services :.NET est + simple, J2EE + scalable Les analystes prédisent les 50/50

Le test : version Microsoft Productivity: Performance: Scalability: One third the code 28 times faster 6 times more users

Performance J2EE &.NET (version MSFT) 2800 2400 2000 8 CPU 4 CPU 2 CPU Nile Application Benchmark Pages Served per Second 1989 2781 1600 1200 977 1240 1154 800 400 291 463 623 231 436 484 538 WebSphere 3.5 JSP on Win 2000 Oracle 8i Microsoft ASP (VBScript) Oracle 8i Microsoft ASP.NET (C#) Oracle 8i Microsoft ASP.NET (C#) SQL Svr 2000

Résumé.NET Java Controller/Owner Microsoft Sun + partenaires Status Langages Produit C#, C++, Eiffel#, VB,... Spécifications et +ieurs implémentations Java + autres possibles Communication, middleware (RPC, Messaging, Web).NET Remoting, MSMQ, Web Services (no ebxml) RMI/CORBA, JMS, Web Services Composents Server COM+ Enterprise JavaBeans Support de XML oui En cours d intégration Server Pages ASP.NET JSP/Servlets

Résumé Accès BD.NET ADO.NET (ADO) Java JDBC / SQLJ & autres Librairies de base System.* java.* GUI-Libs Windows.Forms Web.Forms Swing/AWT Runtime.NET CLR Java JVM Interop (call-in/call-out) PInvoke JNI InteropMiddleware COM/COM+ (COM Interop) CORBA, JMS Legacy Integration Host Integration Server JCA

Résumé Area J2EE.NET Security Deployment Clustering JAAS API Deployment Descriptors EAR, WAR, JAR Container-Specific Container-Specific ASP.NET Form-based Web.config Web.config Machine.config Global.asax XCOPY Deployment Windows.NET DCS SQL Server

Historique JDBC JNDI JMS EJB JSP J2EE JAXP J2EE Microsoft 1996 1997 1998 1999 2000 2001 Mar 1992 ASP MTS/COM+ MSMQ MSXML VS.NET ODBC ADSI WinDNA.NET