Vérification formelle de la plate-forme Java Card
|
|
|
- Alain Laframboise
- il y a 10 ans
- Total affichages :
Transcription
1 Vérification formelle de la plate-forme Java Card Thèse de doctorat Guillaume Dufay INRIA Sophia Antipolis
2 Cartes à puce intelligentes Java Card : Environnement de programmation dédié. Dernières générations de cartes à puce pourvues d un microprocesseur et d un système d exploitation. Stockent et gèrent de l information Communiquent Contiennent plusieurs applications Partagent de l information Information manipulée sensible ou confidentielle. vendredi 5 décembre p.1/32
3 Architecture Java Card Java source Class file Cap file package fr.inri import javacar public class no public Object Java compiler Class File Converter Cap File Builder Chargement Liaison Vérification de bytecode Applet Applet Applet Extensions spécifiques pour l Industrie APIs Machine Virtuelle (JCVM) Environnement d Exécution (JCRE) vendredi 5 décembre p.2/32
4 Problématique Assurer la sécurité de la plate-forme. Formaliser la plate-forme pour raisonner sur celle-ci Méthodologie pour vérifier des propriétés statiques de la plate-forme Automatisation pour faciliter l application de la méthodologie vendredi 5 décembre p.3/32
5 Méthodes formelles Exigées pour garantir la sécurité de systèmes complexes. Langage de spécification suffisamment expressif Système logique et techniques de démonstration Génération de code exécutable et certifié Utilisation de l outil COQ. vendredi 5 décembre p.4/32
6 Méthodologie Vérification d une propriété statique P. Machine P -défensive proche des spécifications P vérifié à l exécution Machine P -offensive proche de l implémentation suppose P déjà vérifié Machine P -abstraite vérifie P uniquement vendredi 5 décembre p.5/32
7 Méthodologie Vérification d une propriété statique P. Machine P -défensive Abstractions Machine P -offensive Machine P -abstraite Analyse statique P -BCV vendredi 5 décembre p.5/32
8 Méthodologie Application à la sûreté du typage. Machine T ype-défensive manipule : valeurs typées types : vérifiés à l exécution Machine T ype-offensive manipule : valeurs non typées correction typage assuré par BCV Machine T ype-abstraite manipule : types comme valeurs vendredi 5 décembre p.5/32
9 Plan Introduction Formalisation de la JCVM Programmes Mémoire Instructions Abstractions Vérification de bytecode Conclusion vendredi 5 décembre p.6/32
10 Réalisations Formalisation en COQ de la JCVM et du JCRE. Intégralité des instructions (sémantique opérationnelle à petit pas) Environnement d exécution (sauf méthodes natives) Spécifications fonctionnelles et exécutables Comparable aux machines virtuelles de référence. vendredi 5 décembre p.7/32
11 Programmes Représentation des programmes après la phase de liaison (réalisée par le JCVM Tools). Record jcprogram : Set := { }. classes methods : (list Class); : (list Method); interfaces : (list Interface); sheap_type : (list type) vendredi 5 décembre p.8/32
12 Programmes Représentation des programmes après la phase de liaison (réalisée par le JCVM Tools). Record Method : Set := { }. signature bytecode : ((list type)*type); : (list Instruction); handler_list : (list handler_type); is_static... : bool; vendredi 5 décembre p.8/32
13 Valeurs Valeurs typées et vérification des types à l exécution. Inductive valu_prim : Set := vbyte : Z valu_prim vshort : Z valu_prim vint : Z valu_prim vboolean : Z valu_prim vreturnaddress : bytecode_idx valu_prim. vendredi 5 décembre p.9/32
14 États Représentation du contenu de la mémoire. Record frame : Set := { opstack : (list valu); locvars : (list (option valu)); p_count : bytecode_idx; owner : package;... }. vendredi 5 décembre p.10/32
15 États Représentation du contenu de la mémoire. Record state : Set := { stack : (list frame); heap : (list obj); sheap : (list valu); }. vendredi 5 décembre p.10/32
16 Exemple d Instruction Definition IF_COND := [b:bytecode_idx][st:state] vendredi 5 décembre p.11/32
17 Exemple d Instruction Definition IF_COND := [b:bytecode_idx][st:state] Cases (stack st) of nil (AbortCode state_error st) (cons f lf) Cases (head (opstack f)) of None (AbortCode opstack_error st) (Some v) vendredi 5 décembre p.11/32
18 Exemple d Instruction Definition IF_COND := [b:bytecode_idx][st:state] Cases (stack st) of nil (AbortCode state_error st) (cons f lf) Cases (head (opstack f)) of None (AbortCode opstack_error st) (Some v) Cases v of (vprim (vshort vx)) _ (AbortCode type_error st) vendredi 5 décembre p.11/32
19 Exemple d Instruction Definition IF_COND := [b:bytecode_idx][st:state] Cases (stack st) of nil (AbortCode state_error st) (cons f lf) Cases (head (opstack f)) of None (AbortCode opstack_error st) (Some v) Cases v of (vprim (vshort vx)) Cases (compare vx 0 ) of true (update_pc b... st) false (update_pc (S (p_count f))... st) end _ (AbortCode type_error st) end end end. vendredi 5 décembre p.11/32
20 Plan Introduction Formalisation de la JCVM Abstractions JCVM offensive JCVM abstraite Génération automatique Vérification de bytecode Conclusion vendredi 5 décembre p.12/32
21 JCVM offensive Manipule des valeurs non typées. Definition valu := Z. Reste de la mémoire inchangé. vendredi 5 décembre p.13/32
22 Exemple d instruction Definition IF_COND := [b:bytecode_idx][st:state] Cases (stack st) of nil (AbortCode state_error st) (cons f lf) Cases (head (opstack f)) of None (AbortCode opstack_error st) (Some v) (* Cases v of *) (* (vprim (vshort vx)) *) Cases (compare v 0 ) of true (update_pc b... st) false (update_pc (S (p_count f))... st) end (* _ (AbortCode type_error st) *) (* end *) end end. vendredi 5 décembre p.14/32
23 Validation croisée Assurer la correction de l abstraction réalisée. Fonction d abstraction α do dstate α do ostate dexec oexec dstate α do ostate Le diagramme commute si la VM défensive ne lève pas d erreurs de typage. vendredi 5 décembre p.15/32
24 JCVM abstraite Manipule pour valeurs des types. Inductive valu_prim : Set := vbyte : (* Z *) valu_prim vshort : (* Z *) valu_prim vint : (* Z *) valu_prim vboolean : (* Z *) valu_prim vreturnaddress : bytecode_idx valu_prim. vendredi 5 décembre p.16/32
25 Mémoire Modèle de mémoire simplifié Definition state := frame. Pas de gestion des exceptions Possible apparition de non-déterminisme vendredi 5 décembre p.17/32
26 Exemple d instruction Definition IF_COND := [b:bytecode_idx][st:state] (* Cases (stack st) of nil (AbortCode state_error st) (cons f lf) *) Cases (head (opstack st)) of None (AbortCode opstack_error st) (Some v) Cases v of (vprim vshort) (* Cases (compare vx 0 ) of *) true (update_pc b... st) false (update_pc (S (p_count f))... st) (* end *) _ (AbortCode type_error st) end end (* end *). vendredi 5 décembre p.18/32
27 Exemple d instruction Definition IF_COND := [b:bytecode_idx][st:state] (* Cases (stack st) of nil (AbortCode state_error st) (cons f lf) *) Cases (head (opstack st)) of None (cons (AbortCode opstack_error st) (nil?)) (Some v) Cases v of (vprim vshort) (* Cases (compare vx 0 ) of *) (cons (update_pc b... st) (cons (update_pc (S (p_count f))... st) (nil?))) (* end *) _ (cons (AbortCode type_error st) (nil?)) end end (* end *). vendredi 5 décembre p.18/32
28 Validation croisée Fonction d abstraction α da dstate dexec dstate α da astate aexec α da astate Le diagramme commute si l exécution reste dans le même contexte et ne lève pas d exceptions. vendredi 5 décembre p.19/32
29 Jakarta Outil pour la génération automatique d abstractions et de preuves de correction. Format de spécification spécifique (avec passerelles) Moteur d abstraction par traduction syntaxique Outil de génération d énoncés de lemmes et de preuves Langage de script pour diriger l abstraction Abstractions réalisées par des scripts d environ 50 lignes pour la VM offensive et 200 lignes pour la VM abstraite. vendredi 5 décembre p.20/32
30 Plan Introduction Formalisation de la JCVM Abstractions Vérification de bytecode Principes Implémentation Instanciation Conclusion vendredi 5 décembre p.21/32
31 Principes Analyse de flot de données du code d un programme. Utilisation des valeurs avec des types corrects Pile d opérande ayant la taille attendue Initialisation des registres et objets avant utilisation Bonne formation du programme Assurer un comportement correct lors de l exécution. vendredi 5 décembre p.22/32
32 Réalisation Analyse basée sur l algorithme de KILDALL. Historique des états pour chacun des points de programme Existence d une fonction d unification sur les états Recherche d un point fixe sur la relation d exécution de la machine virtuelle abstraite Vérification méthode par méthode Différents types d analyses possibles (monovariante, polyvariante,...). vendredi 5 décembre p.23/32
33 Exemple de vérification PC instruction 1 re passe 0: jsr 10 (),[ ; ] 1: iconst_0 2: istore_0 3: jsr 10 4: iload_0 10: astore_1 11: ret 1 États : (Pile d opérande), [Variables locales] vendredi 5 décembre p.24/32
34 Exemple de vérification PC instruction 1 re passe 0: jsr 10 (),[ ; ] 1: iconst_0 2: istore_0 3: jsr 10 4: iload_0 10: astore_1 (RA 0),[ ; ] 11: ret 1 États : (Pile d opérande), [Variables locales] vendredi 5 décembre p.24/32
35 Exemple de vérification PC instruction 1 re passe 0: jsr 10 (),[ ; ] 1: iconst_0 2: istore_0 3: jsr 10 4: iload_0 10: astore_1 (RA 0),[ ; ] 11: ret 1 (),[ ;RA 0] États : (Pile d opérande), [Variables locales] vendredi 5 décembre p.24/32
36 Exemple de vérification PC instruction 1 re passe 0: jsr 10 (),[ ; ] 1: iconst_0 (),[ ;RA 0] 2: istore_0 3: jsr 10 4: iload_0 10: astore_1 (RA 0),[ ; ] 11: ret 1 (),[ ;RA 0] États : (Pile d opérande), [Variables locales] vendredi 5 décembre p.24/32
37 Exemple de vérification PC instruction 1 re passe 0: jsr 10 (),[ ; ] 1: iconst_0 (),[ ;RA 0] 2: istore_0 (int),[ ;RA 0] 3: jsr 10 4: iload_0 10: astore_1 (RA 0),[ ; ] 11: ret 1 (),[ ;RA 0] États : (Pile d opérande), [Variables locales] vendredi 5 décembre p.24/32
38 Exemple de vérification PC instruction 1 re passe 0: jsr 10 (),[ ; ] 1: iconst_0 (),[ ;RA 0] 2: istore_0 (int),[ ;RA 0] 3: jsr 10 (), [int;ra 0] 4: iload_0 10: astore_1 (RA 0),[ ; ] 11: ret 1 (),[ ;RA 0] États : (Pile d opérande), [Variables locales] vendredi 5 décembre p.24/32
39 Exemple de vérification PC instruction 1 re passe 2 e passe 0: jsr 10 (),[ ; ] 1: iconst_0 (),[ ;RA 0] 2: istore_0 (int),[ ;RA 0] 3: jsr 10 (), [int;ra 0] 4: iload_0 10: astore_1 (RA 0),[ ; ] (RA 3),[int;RA 0] 11: ret 1 (),[ ;RA 0] Choix du type de vérification vendredi 5 décembre p.24/32
40 Exemple de vérification PC instruction 1 re passe 2 e passe 0: jsr 10 (),[ ; ] 1: iconst_0 (),[ ;RA 0] 2: istore_0 (int),[ ;RA 0] 3: jsr 10 (), [int;ra 0] 4: iload_0 10: astore_1 (RA 0),[ ; ] (RA 3),[int;RA 0] 11: ret 1 (),[ ;RA 0] Échec de la vérification monovariante vendredi 5 décembre p.24/32
41 Exemple de vérification PC instruction 1 re passe 2 e passe 0: jsr 10 (),[ ; ] 1: iconst_0 (),[ ;RA 0] 2: istore_0 (int),[ ;RA 0] 3: jsr 10 (), [int;ra 0] 4: iload_0 10: astore_1 (RA 0),[ ; ] (RA 3),[int;RA 0] 11: ret 1 (),[ ;RA 0] Vérification polyvariante vendredi 5 décembre p.24/32
42 Exemple de vérification PC instruction 1 re passe 2 e passe 0: jsr 10 (),[ ; ] 1: iconst_0 (),[ ;RA 0] 2: istore_0 (int),[ ;RA 0] 3: jsr 10 (), [int;ra 0] 4: iload_0 10: astore_1 (RA 0),[ ; ] (RA 3),[int;RA 0] 11: ret 1 (),[ ;RA 0] (),[int;ra 3] Vérification polyvariante vendredi 5 décembre p.24/32
43 Exemple de vérification PC instruction 1 re passe 2 e passe 0: jsr 10 (),[ ; ] 1: iconst_0 (),[ ;RA 0] 2: istore_0 (int),[ ;RA 0] 3: jsr 10 (), [int;ra 0] 4: iload_0 (),[int;ra 3] 10: astore_1 (RA 0),[ ; ] (RA 3),[int;RA 0] 11: ret 1 (),[ ;RA 0] (),[int;ra 3] Vérification polyvariante vendredi 5 décembre p.24/32
44 Implémentation Réalisée en COQ sous forme de modules. Module Type BCV. Parameter state : Set. Parameter exec : (relation state). Parameter err : (predicate state). Parameter check : (predicate state). Axiom (decidable check). Axiom a:state.(check a) (reaches err exec a). End BCV. vendredi 5 décembre p.25/32
45 Implémentation Réalisée en COQ sous forme de modules. Module Type Abstract_VM. Parameter state : Set. Parameter err : (predicate state). Parameter loc : Set. Parameter locs : (list loc). Parameter succs : loc state (list loc). Parameter exec : loc state state. End Abstract_VM. vendredi 5 décembre p.25/32
46 Implémentation Paramétrée par le type de vérification souhaité. Module Type Polyvariant_Struct. Declare Module avm : Abstract_VM. Parameter max_length_set : nat. Parameter err_st : state. Axiom (err err_st). Axiom l:loc.(monotone < state End Polyvariant_Struct. (exec l)). Module PVS2SMS [pvs:polyvariant_struct] <: Stackmap_Struct. Module BCV_aexec [sms:stackmap_struct] <: BCV. vendredi 5 décembre p.25/32
47 Compositionnalité Invariant de l exécution défensive établissant une liaison avec l exécution abstraite méthode par méthode. instructions intra-procédurales : résultats de validation croisée appels de méthodes : types des arguments compatibles avec la signature de la méthode retour de méthodes : type de retour compatible avec la signature de la méthode lancement d exceptions : état attendu à l entrée d un gestionnaire vendredi 5 décembre p.26/32
48 Résultats Utilisateur VM Défensive Analyse Polyvariante Fonctions d abstraction Jakarta VM Abstraite Analyse Monovariante Analyse Hybride BCV pour VM Défensive Preuves de correction invocation Validation croisée Théorèmes obtenus : s:dstate. (check s) (reaches err dexec s). s:dstate. (check s) (α do (dexec s))=(oexec (α do s)). vendredi 5 décembre p.27/32
49 Plan Introduction Formalisation de la JCVM Abstractions Vérification de bytecode Conclusion vendredi 5 décembre p.28/32
50 Réalisations Machine virtuelle Java Card complète, avec son environnement d exécution Méthodologie adaptée à la vérification de propriétés sur la plate-forme Appliquée à la vérification du typage Automatisation des tâches Modèle générique et paramétré de BCV vendredi 5 décembre p.29/32
51 Intérêts de l étude Utilisation des méthodes formelles (Critères Communs) Enjeux économiques liés à la sécurité du système Langage de programmation réaliste Originalité de l approche vendredi 5 décembre p.30/32
52 Travaux connexes Java en ACL 2 Projet Bali : Java light en Isabelle/HOL Gemplus : BCV embarquable pour Java Card en Atelier B Axalto et Trusted Logic : Plate-forme Java Card en Coq Secsafe : Sémantique opérationnelle de Carmel pour PVS JBook : Java en ASM-Gofer vendredi 5 décembre p.31/32
53 Perspectives Application de la méthodologie à d autres propriétés Initialisation des objets Non-interférence Disponibilité des ressources Vérificateurs de bytecode optimisés Vérificateurs de bytecode embarqués Passage à Java, C,.Net vendredi 5 décembre p.32/32
54 Merci de votre Attention
55 ? vendredi 5 décembre p.34/32
56 ?! vendredi 5 décembre p.34/32
Vérification formelle de la plate-forme Java Card
UNIVERSITÉ DE NICE - SOPHIA ANTIPOLIS École Doctorale STIC UFR Sciences THÈSE pour obtenir le titre de Docteur en Sciences de l Université de Nice - Sophia Antipolis Spécialité : Informatique présentée
La technologie Java Card TM
Présentation interne au CESTI La technologie Java Card TM [email protected] http://dept-info.labri.u-bordeaux.fr/~sauveron 8 novembre 2002 Plan Qu est ce que Java Card? Historique Les avantages
Traduction des Langages : Le Compilateur Micro Java
BARABZAN Jean-René OUAHAB Karim TUCITO David 2A IMA Traduction des Langages : Le Compilateur Micro Java µ Page 1 Introduction Le but de ce projet est d écrire en JAVA un compilateur Micro-Java générant
Vulgarisation Java EE Java EE, c est quoi?
Paris, le 1 Février 2012 Vulgarisation Java EE Java EE, c est quoi? Sommaire Qu est ce que Java? Types d applications Java Environnements Java Versions de Java Java EE, c est quoi finalement? Standards
Projet de Veille Technologique
Projet de Veille Technologique Programmation carte à puce - JavaCard Ing. MZOUGHI Ines ([email protected]) Dr. MAHMOUDI Ramzi ([email protected]) TEST Sommaire Programmation JavaCard Les prérequis...
Formula Negator, Outil de négation de formule.
Formula Negator, Outil de négation de formule. Aymerick Savary 1,2, Mathieu Lassale 1,2, Jean-Louis Lanet 1 et Marc Frappier 2 1 Université de Limoges 2 Université de Sherbrooke Résumé. Cet article présente
Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs)
Modularité Extensions Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs) généricité modules de première classe : peuvent être
Rappel. Analyse de Données Structurées - Cours 12. Un langage avec des déclaration locales. Exemple d'un programme
Rappel Ralf Treinen Université Paris Diderot UFR Informatique Laboratoire Preuves, Programmes et Systèmes [email protected] 6 mai 2015 Jusqu'à maintenant : un petit langage de programmation
Chapitre VI- La validation de la composition.
Chapitre VI- La validation de la composition. Objectifs du chapitre : Expliquer les conséquences de l utilisation de règles de typage souples dans SEP. Présenter le mécanisme de validation des connexions
LMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. [email protected] www.cril.univ-artois.fr/~jabbour
LMI 2 Programmation Orientée Objet POO - Cours 9 Said Jabbour [email protected] www.cril.univ-artois.fr/~jabbour CRIL UMR CNRS 8188 Faculté des Sciences - Univ. Artois Février 2011 Les collections
Évaluation et implémentation des langages
Évaluation et implémentation des langages Les langages de programmation et le processus de programmation Critères de conception et d évaluation des langages de programmation Les fondations de l implémentation
INTRODUCTION A JAVA. Fichier en langage machine Exécutable
INTRODUCTION A JAVA JAVA est un langage orienté-objet pur. Il ressemble beaucoup à C++ au niveau de la syntaxe. En revanche, ces deux langages sont très différents dans leur structure (organisation du
Conception des systèmes répartis
Conception des systèmes répartis Principes et concepts Gérard Padiou Département Informatique et Mathématiques appliquées ENSEEIHT Octobre 2012 Gérard Padiou Conception des systèmes répartis 1 / 37 plan
Cours 1 : La compilation
/38 Interprétation des programmes Cours 1 : La compilation Yann Régis-Gianas [email protected] PPS - Université Denis Diderot Paris 7 2/38 Qu est-ce que la compilation? Vous avez tous déjà
La JVM. La machine virtuelle Java. La JVM. La JVM
La machine virtuelle Java Historique et rappels Organisation mémoire de la JVM Le garbage collector Le bytecode, la machine à pile. Les threads Suivi, tracé, optimisation d un programme Java JVM embarquées
Classes et Objets en Ocaml.
Classes et Objets en Ocaml. Didier Rémy 2001-2002 http://cristal.inria.fr/ remy/mot/2/ http://www.enseignement.polytechnique.fr/profs/informatique/didier.remy/mot/2/ Cours Exercices Slide 1 1. Objets 2.
La carte à puce. Jean-Philippe Babau
La carte à puce Jean-Philippe Babau Département Informatique INSA Lyon Certains éléments de cette présentation sont issus de documents Gemplus Research Group 1 Introduction Carte à puce de plus en plus
Programmation. fonctionnelle, impérative, logique et orientée objet
Programmation fonctionnelle, impérative, logique et orientée objet Introduction Les langages de programmation permettent de décrire des calculs de façon plus abstraite qu'un programme machine. Les programmes
Automatisation de l administration système
Automatisation de l administration système Plan Problèmatique : trop de systèmes, trop de solutions Typage des solutions Puppet : gestion de configuration de systèmes Capistrano : déploiement d applications
Automatic generation of vulnerability tests for the Java Card byte code verifier
Automatic generation of vulnerability tests for the Java Card byte code verifier Aymerick Savary GRIL, Département Informatique, Université de Sherbrooke, Québec, Canada Email: [email protected]
Objets et Programmation. origine des langages orientés-objet
Objets et Programmation origine des langages orientés-objet modularité, encapsulation objets, classes, messages exemples en Java héritage, liaison dynamique G. Falquet, Th. Estier CUI Université de Genève
Introduction aux Machines Virtuelles avec VMKit
Introduction aux Machines Virtuelles avec Ingénieur :, Responsables : Gaël Thomas, Gilles Müller EQUIPE REGAL LIP6 INRIA (Paris/France) un substrat de machine virtuelle : a substrate for Managed Runtime
Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée
Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée forax at univ-mlv dot fr - ParisJUG Java.next() - Mars 2012 What Else? Lambda == Inner class? Java a des lambdas depuis la version 1.1 Exemple utilisant
IN 102 - Cours 1. 1 Informatique, calculateurs. 2 Un premier programme en C
IN 102 - Cours 1 Qu on le veuille ou non, les systèmes informatisés sont désormais omniprésents. Même si ne vous destinez pas à l informatique, vous avez de très grandes chances d y être confrontés en
Mécanismes pour la migration de processus
Université Joseph Fourier Institut National Polytechnique de Grenoble U.F.R. Informatiques & Mathématiques Appliquées ENSIMAG I.M.A.G. DEA D INFORMATIQUE : SYSTEMES ET COMMUNICATIONS Projet présenté par
Théorie de la Programmation
Théorie de la Programmation http://perso.ens-lyon.fr/daniel.hirschkoff/thpr hop Programmation, Théorie de la programmation Langages de programmation I il existe de nombreux langages de programmation I
TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile
TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile Dans ce TP, vous apprendrez à définir le type abstrait Pile, à le programmer en Java à l aide d une interface
Algorithmique des Systèmes Répartis Protocoles de Communications
Algorithmique des Systèmes Répartis Protocoles de Communications Master Informatique Dominique Méry Université de Lorraine 1 er avril 2014 1 / 70 Plan Communications entre processus Observation et modélisation
Compilation (INF 564)
Présentation du cours Le processeur MIPS Programmation du MIPS 1 Compilation (INF 564) Introduction & architecture MIPS François Pottier 10 décembre 2014 Présentation du cours Le processeur MIPS Programmation
Java et les bases de données: JDBC: Java DataBase Connectivity SQLJ: Embedded SQL in Java. Michel Bonjour http://cuiwww.unige.
: JDBC: Java DataBase Connectivity SQLJ: Embedded SQL in Java Michel Bonjour http://cuiwww.unige.ch/~bonjour Plan JDBC: API bas niveau pour l accès aux BD (SQL) - Introduction - JDBC et : Java, ODBC, SQL
GenDbg : un débogueur générique. Didier Eymery Jean-Marie Borello Jean-Marie Fraygefond Odile Eymery Philippe Bion
GenDbg : un débogueur générique Didier Eymery Jean-Marie Borello Jean-Marie Fraygefond Odile Eymery Philippe Bion 2008 Qui sommes nous? Centre d électronique de l Armement (CELAR) Maîtrise et protection
Machines virtuelles Cours 1 : Introduction
Machines virtuelles Cours 1 : Introduction Pierre Letouzey 1 [email protected] PPS - Université Denis Diderot Paris 7 janvier 2012 1. Merci à Y. Régis-Gianas pour les transparents Qu est-ce qu une
Programmer en JAVA. par Tama ([email protected]( [email protected])
Programmer en JAVA par Tama ([email protected]( [email protected]) Plan 1. Présentation de Java 2. Les bases du langage 3. Concepts avancés 4. Documentation 5. Index des mots-clés 6. Les erreurs fréquentes
Vérification de programmes et de preuves Première partie. décrire des algorithmes
Vérification de programmes et de preuves Première partie. décrire des algorithmes Yves Bertot September 2012 1 Motivating introduction A partir des années 1940, il a été compris que l on pouvait utiliser
Cours de Java. Sciences-U Lyon. Java - Introduction Java - Fondamentaux Java Avancé. http://www.rzo.free.fr
Cours de Java Sciences-U Lyon Java - Introduction Java - Fondamentaux Java Avancé http://www.rzo.free.fr Pierre PARREND 1 Octobre 2004 Sommaire Java Introduction Java Fondamentaux Histoire de Java Machine
Programmation Web. Madalina Croitoru IUT Montpellier
Programmation Web Madalina Croitoru IUT Montpellier Organisation du cours 4 semaines 4 ½ h / semaine: 2heures cours 3 ½ heures TP Notation: continue interrogation cours + rendu à la fin de chaque séance
Machines virtuelles. Brique ASC. Samuel Tardieu [email protected]. Samuel Tardieu (ENST) Machines virtuelles 1 / 40
Machines virtuelles Brique ASC Samuel Tardieu [email protected] École Nationale Supérieure des Télécommunications Samuel Tardieu (ENST) Machines virtuelles 1 / 40 Machines virtuelles La compilation peut
Programmation Bas Niveau
Programmation Bas Niveau Basé en grande partie sur les notes de Etienne Payet et Fausto Spoto 1 Université de La Réunion FST - L2 Info Introduction 2 Module Machines virtuelles (Java), bytecode, etc. 30h
Analyse de sécurité de logiciels système par typage statique
Contexte Modélisation Expérimentation Conclusion Analyse de sécurité de logiciels système par typage statique Application au noyau Linux Étienne Millon UPMC/LIP6 Airbus Group Innovations Sous la direction
Alfstore workflow framework Spécification technique
Alfstore workflow framework Spécification technique Version 0.91 (2012-08-03) www.alfstore.com Email: [email protected] Alfstore workflow framework 2012-10-28 1/28 Historique des versions Version Date
MEMOIRE. Présenté à. L École Nationale d Ingénieurs de Sfax. en vue de l obtention du MASTERE
République Tunisienne Ministère de l Enseignement Supérieur, De la Recherche Scientifique et de la Technologie Université de Sfax École Nationale d Ingénieurs de Sfax Ecole Doctorale Sciences et Technologies
Cours de Programmation 2
Cours de Programmation 2 Programmation à moyenne et large échelle 1. Programmation modulaire 2. Programmation orientée objet 3. Programmation concurrente, distribuée 4. Programmation monadique 5. Les programmes
SSTIC 2009. Désobfuscation automatique de binaires. Alexandre Gazet. Yoann Guillot. Et autres idyles bucoliques...
Désobfuscation automatique de binaires Et autres idyles bucoliques... Alexandre Gazet Sogeti / ESEC R&D alexandre.gazet(at)sogeti.com Yoann Guillot Sogeti / ESEC R&D yoann.guillot(at)sogeti.com SSTIC 2009
Le Collège de France crée une chaire pérenne d Informatique, Algorithmes, machines et langages, et nomme le Pr Gérard BERRY titulaire
Communiquédepresse Mars2013 LeCollègedeFrancecréeunechairepérenned Informatique, Algorithmes,machinesetlangages, etnommeleprgérardberrytitulaire Leçoninauguralele28mars2013 2009avait marquéunpas importantdans
Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. [email protected]
. Cours intensif Java 1er cours: de C à Java Septembre 2009 Enrica DUCHI LIAFA, Paris 7 [email protected] LANGAGES DE PROGRAMMATION Pour exécuter un algorithme sur un ordinateur il faut le
Virtualisation logicielle De la machine réelle à la machine virtuelle abstraite
Virtualisation logicielle De la machine réelle à la machine virtuelle abstraite Bertil FOLLIOT et Gaël THOMAS Cette version est une préversion de l article accepté par «Technique de l ingénieur» (Hermes).
IFT2255 : Génie logiciel
IFT2255 : Génie logiciel Chapitre 6 - Analyse orientée objets Section 1. Introduction à UML Julie Vachon et Houari Sahraoui 6.1. Introduction à UML 1. Vers une approche orientée objet 2. Introduction ti
Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if
Éléments d informatique Cours 3 La programmation structurée en langage C L instruction de contrôle if Pierre Boudes 28 septembre 2011 This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike
TP 1. Prise en main du langage Python
TP. Prise en main du langage Python Cette année nous travaillerons avec le langage Python version 3. ; nous utiliserons l environnement de développement IDLE. Étape 0. Dans votre espace personnel, créer
Proposition de stage
Implémentation d un éditeur collaboratif de documents sous Oracle Implémentation d un éditeur euroscript Systems La Fleuriaye Espace Performance II Rue du Professeur Rouxel Bât. D2 BP 30738-44481 CARQUEFOU
OCL - Object Constraint Language
OCL - Object Constraint Language Laëtitia Matignon [email protected] Département Informatique - Polytech Lyon Université Claude Bernard Lyon 1 2012-2013 Laëtitia Matignon SIMA - OCL - Object
Gestion mémoire et Représentation intermédiaire
Gestion mémoire et Représentation intermédiaire Pablo de Oliveira March 23, 2015 I Gestion Memoire Variables locales Les variables locales sont stockées: Soit dans un registre,
Plan du cours. Historique du langage http://www.oracle.com/technetwork/java/index.html. Nouveautés de Java 7
Université Lumière Lyon 2 Faculté de Sciences Economiques et Gestion KHARKIV National University of Economic Introduction au Langage Java Master Informatique 1 ère année Julien Velcin http://mediamining.univ-lyon2.fr/velcin
Gestion hybride de la mémoire dynamique dans les systèmes Java temps-réel
Gestion hybride de la mémoire dynamique dans les systèmes Java temps-réel Nicolas Berthier Stage de Magistère M encadré par Christophe Rippert et Guillaume Salagnac Laboratoire Vérimag Septembre 007 Résumé
Calculabilité Cours 3 : Problèmes non-calculables. http://www.irisa.fr/lande/pichardie/l3/log/
Calculabilité Cours 3 : Problèmes non-calculables http://www.irisa.fr/lande/pichardie/l3/log/ Problèmes et classes de décidabilité Problèmes et classes de décidabilité Nous nous intéressons aux problèmes
TP1 : Initiation à Java et Eclipse
TP1 : Initiation à Java et Eclipse 1 TP1 : Initiation à Java et Eclipse Systèmes d Exploitation Avancés I. Objectifs du TP Ce TP est une introduction au langage Java. Il vous permettra de comprendre les
UE 8 Systèmes d information de gestion Le programme
UE 8 Systèmes d information de gestion Le programme Légende : Modifications de l arrêté du 8 mars 2010 Suppressions de l arrêté du 8 mars 2010 Partie inchangée par rapport au programme antérieur Indications
Structure d un programme et Compilation Notions de classe et d objet Syntaxe
Cours1 Structure d un programme et Compilation Notions de classe et d objet Syntaxe POO 1 Programmation Orientée Objet Un ensemble d objet qui communiquent Pourquoi POO Conception abstraction sur les types
Introduction à Java. Philippe Genoud. [email protected]. http://www.inrialpes.fr/helix/people/genoud/ensjava
Introduction à Java Philippe Genoud [email protected] http://www.inrialpes.fr/helix/people/genoud/ensjava http://membres-liglab.imag.fr/genoud/ensjava/m2cci/ 1 JAVA c'est quoi? Une technologie développée
Programmation Orientée Objet
Université de Pau et des Pays de l Adour Institut Universitaire de Technologie des Pays de l Adour Département Réseaux et Télécommunications 371, rue du Ruisseau BP 201 40004 Mont-de-Marsan Cedex tél :
as Architecture des Systèmes d Information
Plan Plan Programmation - Introduction - Nicolas Malandain March 14, 2005 Introduction à Java 1 Introduction Présentation Caractéristiques Le langage Java 2 Types et Variables Types simples Types complexes
Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf
Introduction à Java Matthieu Herrb CNRS-LAAS http://homepages.laas.fr/matthieu/cours/java/java.pdf Mars 2014 Plan 1 Concepts 2 Éléments du langage 3 Classes et objets 4 Packages 2/28 Histoire et motivations
Cours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java
Langages objets Introduction M2 Pro CCI, Informatique Emmanuel Waller, LRI, Orsay présentation du module logistique 12 blocs de 4h + 1 bloc 2h = 50h 1h15 cours, 45mn exercices table, 2h TD machine page
Rapport de certification
Rapport de certification BMC Real End User Experience Monitoring and Analytics 2.5 Préparé par le Centre de la sécurité des télécommunications à titre d organisme de certification dans le cadre du Schéma
Programmation en Java IUT GEII (MC-II1) 1
Programmation en Java IUT GEII (MC-II1) 1 Christophe BLANC - Paul CHECCHIN IUT Montluçon Université Blaise Pascal Novembre 2009 Christophe BLANC - Paul CHECCHIN Programmation en Java IUT GEII (MC-II1)
modèles génériques applicables à la synthèse de contrôleurs discrets pour l Internet des Objets
modèles génériques applicables à la synthèse de contrôleurs discrets pour l Internet des Objets Mengxuan Zhao, Gilles Privat, Orange Labs, Grenoble, France Eric Rutten, INRIA, Grenoble, France Hassane
Master Informatique Aix-Marseille Université
Aix-Marseille Université http://masterinfo.univ-mrs.fr/ Département Informatique et Interactions UFR Sciences Laboratoire d Informatique Fondamentale Laboratoire des Sciences de l Information et des Systèmes
Projet Active Object
Projet Active Object TAO Livrable de conception et validation Romain GAIDIER Enseignant : M. Noël PLOUZEAU, ISTIC / IRISA Pierre-François LEFRANC Master 2 Informatique parcours MIAGE Méthodes Informatiques
Exclusion Mutuelle. Arnaud Labourel Courriel : [email protected]. Université de Provence. 9 février 2011
Arnaud Labourel Courriel : [email protected] Université de Provence 9 février 2011 Arnaud Labourel (Université de Provence) Exclusion Mutuelle 9 février 2011 1 / 53 Contexte Epistémologique
La dernière base de données de Teradata franchit le cap du big data grâce à sa technologie avancée
Communiqué de presse Charles-Yves Baudet Twitter: Les clients de Teradata Teradata Corporation peuvent [email protected] tirer parti de plusieurs + 33 1 64 86 76 14 + 33 (0) 1 55 21 01 48/49 systèmes,
Une introduction à Java
Une introduction à Java IFT 287 (Semaine 1) UNIVERSITÉ DE SHERBROOKE 1 Java - Historique Développé par Sun Microsystems en 1994 Inventeur James Gosling (canadien!) Objectif langage sûr (fortement typé)
Sélection du contrôleur
Démo CoDeSys - 1 - 1. Configuration de l environnement de travail : Lancer le logiciel CoDeSys Fichier Nouveau Lors de la première utilisation, une boîte de dialogue apparaît permettant la sélection du
Threads. Threads. USTL http://www.lifl.fr/ routier 1
Threads USTL http://www.lifl.fr/ routier 1 Rappels - Définitions un Process est un programme qui tourne et dispose de ses propres ressources mémoire. OS multi-tâche plusieurs process en concurrence un
HMI target Visu / PLC HMI. Pour réaliser une interface homme machine avec PLC control
HMI target Visu / PLC HMI Pour réaliser une interface homme machine avec PLC control VERSION : 1.4 / PH DATE : 5 Novembre 2014 Sommaire Ce manuel explique de manière pratique les étapes successives pour
Groupe Eyrolles, 2004, ISBN : 2-212-11274-2
Groupe Eyrolles, 2004, ISBN : 2-212-11274-2 Table des matières Remerciements.................................................. Avant-propos.................................................... Structure
Dispositif sur budget fédéral
w w w. c n f e t p. c o m R é f o r m e B T S S I O Services Informatiques aux Organisations Dispositif sur budget fédéral 31 rue des Naudières 44400 REZE Tél. 02 40 32 88 00 Fax 02 40 84 12 95 [email protected]
Cours A7 : Temps Réel
Cours A7 : Temps Réel Pierre.Paradinas / @ / cnam.fr Cnam/Cedric Systèmes Enfouis et Embarqués (SEE) Motivations Du jour : les mécanismes multitâches, la gestion des priorités, l ordonnancement, la gestion
RTDS G3. Emmanuel Gaudin [email protected]
RTDS G3 Emmanuel Gaudin [email protected] PragmaDev Dédiée au développement d un AGL pour le développement des applications temps réel et embarquées. Réseau de partenaires: Formations, Service,
Remote Method Invocation (RMI)
Remote Method Invocation (RMI) TP Réseau Université Paul Sabatier Master Informatique 1 ère Année Année 2006/2007 Plan Objectifs et Inconvénients de RMI Fonctionnement Définitions Architecture et principe
Christophe Pagezy Directeur Général [email protected] Mob: 06 2101 6218
Christophe Pagezy Directeur Général [email protected] Mob: 06 2101 6218 77, avenue Niel, 75017 Paris, France Prove & Run - CONFIDENTIEL 1 La sécurité des objets connectés : problématiques
PROGRAMME DETAILLE. Parcours en première année en apprentissage. Travail personnel. 4 24 12 24 CC + ET réseaux
PROGRAMME DETAILLE du Master IRS Parcours en première année en apprentissage Unités d Enseignement (UE) 1 er semestre ECTS Charge de travail de l'étudiant Travail personnel Modalités de contrôle des connaissances
Cours Composant 2. Qualité logicielle et spécications algébriques
UPMC Paris Universitas Master Informatique STL Cours Composant 2. Qualité logicielle et spécications algébriques c 2005-2008 Frédéric Peschanski UPMC Paris Universitas 24 février 2008 c 2005-2008 Frédéric
Semestre 1. Objectifs Approfondissement de l environnement Java et de son interface de programmation d applications : réseaux, et processus.
Programmation Java avancée (3 ECTS 36h) Semestre 1 Approfondissement de l environnement Java et de son interface de programmation d applications : réseaux, et processus. Introduction. Rappels des concepts
REQUEA. v 1.0.0 PD 20 mars 2008. Mouvements d arrivée / départ de personnels Description produit
v 1.0.0 PD 20 mars 2008 Mouvements d arrivée / départ de personnels Description produit Fonctionnalités L application Gestion des mouvements d arrivée / départ de Requea permet la gestion collaborative
Proposition de sujet de thèse CIFRE EUROCOPTER / LGI2P
EUROCOPTER SAS Groupe EADS Marignane Ecole des Mines d Alès Laboratoire de Génie Informatique et d Ingénierie de Production LGI2P Nîmes Proposition de sujet de thèse CIFRE EUROCOPTER / LGI2P Titre Domaine
Licence Bio Informatique Année 2004-2005. Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...
Université Paris 7 Programmation Objet Licence Bio Informatique Année 2004-2005 TD n 1 - Correction Premiers pas Exercice 1 Hello World parce qu il faut bien commencer par quelque chose... 1. Enregistrez
Module BD et sites WEB
Module BD et sites WEB Cours 8 Bases de données et Web Anne Doucet [email protected] 1 Le Web Architecture Architectures Web Client/serveur 3-tiers Serveurs d applications Web et BD Couplage HTML-BD
Chapitre 2 : Abstraction et Virtualisation
Virtualisation et Cloud Computing Chapitre 2 : Abstraction et Virtualisation Objectifs Présenter la notion de niveaux d abstraction séparés par des interfaces bien définies Description des avantages et
Java DataBaseConnectivity
Java DataBaseConnectivity JDBC JDBC est une API Java (ensemble de classes et d interfaces défini par SUN et les acteurs du domaine des SGBD) permettant d accéder aux bases de données à l aide du langage
Java c est quoi? Java pourquoi?
Grandes lignes du cours Cours JAVA : Le bases du langage Java. Version 3.02 Julien Sopena 1 1 [email protected] Équipe REGAL - INRIA Rocquencourt LIP6 - Université Pierre et Marie Curie Licence professionnelle
NFP111 Systèmes et Applications Réparties
NFP111 Systèmes et Applications Réparties 1 de 34 NFP111 Systèmes et Applications Réparties Cours 7 - CORBA/Partie 1 Claude Duvallet Université du Havre UFR Sciences et Techniques 25 rue Philippe Lebon
BUSINESS INTELLIGENCE. Une vision cockpit : utilité et apport pour l'entreprise
BUSINESS INTELLIGENCE Une vision cockpit : utilité et apport pour l'entreprise 1 Présentation PIERRE-YVES BONVIN, SOLVAXIS BERNARD BOIL, RESP. SI, GROUPE OROLUX 2 AGENDA Définitions Positionnement de la
Java et les bases de données
Michel Bonjour http://cuiwww.unige.ch/~bonjour CENTRE UNIVERSITAIRE D INFORMATIQUE UNIVERSITE DE GENEVE Plan Introduction JDBC: API SQL pour Java - JDBC, Java, ODBC, SQL - Architecture, interfaces, exemples
Brique BDL Gestion de Projet Logiciel
Brique BDL Gestion de Projet Logiciel Processus de développement pratiqué à l'enst [email protected] url:http://www.infres.enst.fr/~vignes/bdl Poly: Computer elective project F.Gasperoni Brique BDL
Rappels d architecture
Assembleur Rappels d architecture Un ordinateur se compose principalement d un processeur, de mémoire. On y attache ensuite des périphériques, mais ils sont optionnels. données : disque dur, etc entrée
Rapport de Synthèse. Création d un Générateur de modèle PADL pour le langage C++ Sébastien Colladon
L Y O N Département Informatique Année 2011/2012 Rapport de Synthèse Création d un Générateur de modèle PADL pour le langage C++ Sébastien Colladon Laboratoire Ptidej de L Ecole Polytechnique de Montréal
Des réels aux flottants : préservation automatique de preuves de stabilité de Lyapunov
Des réels aux flottants : préservation automatique de preuves de stabilité de Lyapunov Olivier Hermant et Vivien Maisonneuve CRI, MINES ParisTech, PSL Research University [email protected]
Offre Référentiel d échange
Offre Référentiel d échange mardi 1er juillet 2014 Groupe CGI inc. CONFIDENTIEL Agenda 1 2 3 4 5 6 7 8 Pourquoi cette solution? Les enjeux et principes de la solution Les acteurs & business case Sa place
Génie Logiciel avec Ada. 4 février 2013
Génie Logiciel 4 février 2013 Plan I. Généralités II. Structures linéaires III. Exceptions IV. Structures arborescentes V. Dictionnaires I. Principes II. Notions propres à la POO I. Principes Chapitre
