Symfony. IRT Programmation côté serveur. Symfony. Rappels

Save this PDF as:
 WORD  PNG  TXT  JPG

Dimension: px
Commencer à balayer dès la page:

Download "Symfony. IRT 2009-2010 Programmation côté serveur. Symfony. Rappels"

Transcription

1 UPMC IRT c by C.Queinnec 3/42 UPMC IRT c by C.Queinnec 4/42 Symfony Revision: 1.1 IRT Programmation côté serveur Symfony C.Queinnec Symfony est un framework, une architecture pour projet d applications web MVC : Model View Control Convention over configuration KISS : Keep It Simple, Stupid! DRY : Don t Repeat Yourself! né en 2005 en France (Fabien Potencier, Sensio) http :// UPMC IRT c by C.Queinnec 1/42 UPMC IRT c by C.Queinnec 2/42 Rappels Programmation par objets : définir classe, héritage instancier classe, accéder/modifier champs méthode, référence à soi, à super class A extends B { private champ1 = 0; public function method1 ($v) { $this->champ1 = $v + $this->champ1; protected function method2 (type $w) { return new B($w);

2 UPMC IRT c by C.Queinnec 7/42 UPMC IRT c by C.Queinnec 8/42 Projet Applications Au début est le projet un outil en ligne de commande automatise de nombreuses tâches Un projet comporte plusieurs applications par exemple, frontend, backend... % symfony generate:app frontend % alias symfony=/lib/vendor/symfony-1.4.3/data/bin/symfony % ls -F apps/frontend/ % cd ~/public_html/ config/ i18n/ lib/ modules/ templates/ % symfony help % ls apps/frontend/config/ % symfony help generate:project app.yml frontendconfiguration.class.php % symfony generate:project pcs cache.yml routing.yml % ls -F pcs/ factories.yml security.yml apps/ config/ lib/ plugins/ test/ filters.yml view.yml cache/ data/ log/ symfony/ web/ % ls apps/frontend/templates/ layout.php UPMC IRT c by C.Queinnec 5/42 UPMC IRT c by C.Queinnec 6/42 Syntaxe YAML et cela fonctionne! L application peut être tourné en mode production, développement, test... Voir la barre d outils en mode développement. Attention : aucune tabulation. Attention aux alignements. hash: cle1: valeur1 cle2: - item1 - item2 cle3: { cle3a: vala, cle3b: valb # Commentaire nom: valeur Et plein d autres choses encore...

3 UPMC IRT c by C.Queinnec 11/42 UPMC IRT c by C.Queinnec 12/42 Modèle de données Indiquer les données de connexion dans config/databases.yml ainsi que l ORM (Object Relational Mapping) à utiliser : ici Doctrine. all: doctrine: class: sfdoctrinedatabase param: dsn: mysql:host=localhost;dbname=pcs username: X # password: Y Base de données La mémoire commune, l état de l application, le lieu d échange, le principe synchronisant des applications Web! corollaire de l architecture à couches (3-tiers) Présentation Métier Présentation Présentation Présentation Métier Métier Métier BD BD +réplication UPMC IRT c by C.Queinnec 9/42 Concepts de BD UPMC IRT c by C.Queinnec 10/42 Usage de BD table, clés primaires/étrangères (intégrité référentielle) langage ensembliste : SQL transactions index, vue, réflexe (trigger),... Types de données : classique + temps + grandes séquences d octets ou de caractères (accès par flux) Interfaçage : ODBC, JDBC principalement via des chaînes de requêtes SQL établissement de la connexion (via un DSN data source name) à une base puis, un certain nombre de fois : établissement (implicite ou pas) d un mode transactionnel puis, un certain nombre de fois : préparation de requête appel de requête (type select) récupération des données sélectionnées (gestion de curseur) ou exécution d une requête à effet secondaire (update, delete, etc.) ou d administration (create temporary table, create index, etc.) validation ou pas de la transaction terminaison de connexion

4 UPMC IRT c by C.Queinnec 15/42 UPMC IRT c by C.Queinnec 16/42 Relationnel/Objet Première idée : une ligne de table = un objet table T int a text b 42 foo timestamp c 2008feb04 09:51 T a b c 42 StringBuffer foo Date 2008 feb Lien entre ligne et objet La clé primaire est le lien Elle doit pouvoir être calculée à partir de l objet et de la ligne Elle permet d assurer l unicité de l objet remonté de la base table T int a text b 42 foo timestamp c 2008feb04 09:51 bd, T, CleP(a,b,c) H T a b c 42 StringBuffer foo Date 2008 feb UPMC IRT c by C.Queinnec 13/42 Modifications UPMC IRT c by C.Queinnec 14/42 Traitement des références Modifier l objet doit se répercuter dans la base. Pour cela, il faut traquer les modifications en imposant l usage de modifieurs. En fin de transaction (ou à des moments choisis), collecter les objets modifiés et engendrer la série de requêtes : unt->setfield(newvalue) update T set field = newvalue,... where... cleprimaire()...; Un impératif : chargement paresseux des lignes! Traquer les lectures de clés étrangères pour en profiter pour charger la ligne référencée (mêmes techniques que précédemment) Un chargement demande un select un peu plus de doigté pour les mises à jour dans la modification de la référence (seulement sur des objets remontés (chargés ou non)) dans la génération des requêtes de mise à jour update T set field = referredobject.primarykey,... where... cleprimaire()...;

5 UPMC IRT c by C.Queinnec 19/42 UPMC IRT c by C.Queinnec 20/42 Collections table T1... ref T2 table T2... foo... text e bd, T1, clep bd, T2, foo... foo H X X T1_DB loaded bd T1 CleP... T2_DB??? bd T2 foo?????? Certaines clés étrangères mènent à un ensemble de lignes matérialisant ainsi une relation 1 :n. create table CD { id int primary key, title text not null create table Track { id int primary key, cd_id int not null references CD, title text not null Un CD a un contenu : les pistes qui le mentionnent comme CD. On veut écrire uncd.tracks() et obtenir l ensemble des objets Track qu il comporte. UPMC IRT c by C.Queinnec 17/42 Opérations usuelles UPMC IRT c by C.Queinnec 18/42 Convention/configuration Création fabrique A.create(...) sélection unaire A.find(clePrimaire) sélection multiple A.select(criteres) criteres définit la clause where et est souvent un objet structuré Usage lecture una.getfield() mène à valeur ou objet modification una.setfield(...) mise à jour de la base unaire una.update() générale update() Suppression unaire una.delete() multiple A.delete(criteres) Un slogan assez populaire en ce moment (Maven, Rails, etc.) est «suivre les conventions est préférable à configurer» (convention over configuration) ce qui implique qu une configuration par défaut doit exister et être raisonnable. unifier noms de classe et noms de table (caractères permis, mots clés exclus) unifier noms de champs et noms de colonnes choisir des types compatibles systématiquement passer par des méthodes Mais on peut toujours tout configurer!

6 UPMC IRT c by C.Queinnec 23/42 UPMC IRT c by C.Queinnec 24/42 Méthodes de configuration CRUD base = descripteur = code descripteur = code + base code + annotation = base (dilution descripteur en code) Le descripteur est le pivot. concept A champ type a nom SQL a nom (Java Perl PHP) a cle primaire... nom table SQL A nom classe (Java Perl PHP) A raccourci possible C c relation 1:n nom D d CRUD = Create, Retrieve, Update, Delete À partir du descripteur, on peut bâtir une webapp entière pour administrer une base (exemple phpmyadmin). On peut adjoindre des informations stylistiques. On peut aussi utiliser les seules méta-données (moins riches) de la base (ce que fait par exemple MayPole) UPMC IRT c by C.Queinnec 21/42 UPMC IRT c by C.Queinnec 22/42 Harmonisation Limitations mise à jour procédurale Comment marier du code engendré automatiquement avec du code métier ou de la présentation? Sachant que la base évolue, que le code métier se ramifie, que la vitesse de présentation peut devenir critique, que la vitesse de re-déploiement peut devenir dirimante,... update Person set age = age + 1 where birth = current_day; remontée conjointe de données de plusieurs tables select p.*, m.* from Person p, Mark m where p.id = m.person_id; persistance structurelle par classe/table et non par atteignabilité

7 UPMC IRT c by C.Queinnec 27/42 UPMC IRT c by C.Queinnec 28/42 Autres problèmes Manipulation de multiples bases transaction multi-bases Qualité des données le DSN identifiant la base correspond à un unique utilisateur de la base. pas de transactions longues avec le Web UPMC IRT c by C.Queinnec 25/42 Mise en œuvre % symfony doctrine:build-model % find /lib/model/doctrine/ % symfony doctrine:build-sql % more data/sql/schema.sql % symfony doctrine:insert-sql % echo show tables; describe person; mysql pcs % symfony doctrine:build-forms % symfony doctrine:build-filters Définition de la base Dans config/doctrine/schema.yml Person: columns: name: { type: string(255), notnull: true comment: { type: string(255), notnull: false password: { type: string(255), notnull: true last: { type: timestamp, notnull: false relations: LoadAverage: local: last foreign: instant LoadAverage: columns: instant: { type: timestamp, notnull: true users: { type: integer, notnull: true load1: { type: float, notnull: true load5: { type: float, notnull: true load15: { type: float, notnull: true UPMC IRT c by C.Queinnec 26/42 Remplissage initial base Plutôt qu écrire en Sql, cf. data/fixtures/fixtures.yml LoadAverage: genese: instant: T00:00:00Z users: 0 load1: 0 load5: 0 load15: 0 Person: LouisXX: name: Louis XX comment: prochain roi de France? password: bof last: genese CneNemo: name: Capitaine Nemo comment: sous-marinier de papier password: gloup last: genese % symfony doctrine:data-load % echo select * from person; mysql pcs

8 Requêtes Doctrine::getTable( Person ) ->createquery() ->where("name =?", "qqch") ->execute(); // select * from Person where name = "qqch" Manipulations $person->setname($person->getname()); $person->delete(); Lire les fichiers dans lib/model/doctrine/ Doctrine::getTable( Person ) ->find(id); // select * from Person where id =? UPMC IRT c by C.Queinnec 29/42 Modules Une application est structurée en modules : un regroupement de pages et d actions % symfony generate:module frontend person % symfony generate:module frontend loadaverage % ls apps/frontend/modules/person/actions/ actions.class.php % ls apps/frontend/modules/person/templates/ indexsuccess.php Voir avec UPMC IRT c by C.Queinnec 31/42 UPMC IRT c by C.Queinnec 30/42 MVC Toute requête arrive au contrôleur général de Symfony qui analyse l URL pour la router vers une action d un module selon des règles apps/a/config/routing.yml L action (incarnée par une méthode executex dans le fichier apps/a/modules/m/actions/actions.class.php) renvoie un code permettant d en déduire la vue (le patron) à utiliser ainsi que les données utiles à la génération de la vue La vue (incarnée par un fichier apps/frontend/modules/m/templates/xsuccess.php) engendre l HTML qui sera inclus dans une page HTML définie par apps/frontend/templates/layout.php UPMC IRT c by C.Queinnec 32/42

9 UPMC IRT c by C.Queinnec 35/42 UPMC IRT c by C.Queinnec 36/42 Routage homepage: url: / # param: { module: default, action: index param: { module: person, action: index person_show: url: /person/:id class: sfdoctrineroute options: { model: Person, type: object param: { module: person, action: show requirements: id: \d+ sf_method: [get] default_index: url: /:module param: { action: index default: url: /:module/:action/* UPMC IRT c by C.Queinnec 33/42 Vue Actions public function executeindex(sfwebrequest $request) { // $this->forward( default, module ); $this->persons = Doctrine::getTable( Person ) ->createquery() ->execute(); return sfview::success; UPMC IRT c by C.Queinnec 34/42 Page <table> <thead> <tr> <th>nom</th> <th>commentaire</th> </tr> </thead> <tbody> <?php foreach ($persons as $person):?> <tr><td><a href= <?php echo url_for( person_show, $person) </head>?> > <?php echo $person->getname()?></a></td> <td><?php echo $person->getcomment()?></td> </tr> <?php endforeach;?> </tbody> </table> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " g/tr/xhtml1/dtd/xhtml1-transitional.dtd"> <html xmlns=" xml:lang="en" lang="e <head> <?php include_http_metas()?> <?php include_metas()?> <?php include_title()?> <link rel="shortcut icon" href="/favicon.ico" /> <?php include_stylesheets()?> <?php include_javascripts()?> <body> <div><a href= <?php echo )?> >Home</a> </div> <h1>bonjour Symfony</h1> <?php echo $sf_content?> </body> </html>

10 UPMC IRT c by C.Queinnec 39/42 UPMC IRT c by C.Queinnec 40/42 Fonctionnalités avancées // dans indexsuccess.php <?php echo link_to( [DELETE], person_delete, $person, array( method => delete, confirm => Vraiment? ))?> // dans routing.yml person_delete: url: /person/:id class: sfdoctrineroute options: { model: Person, type: object param: { module: person, action: delete requirements: id: \d+ sf_method: [delete] // dans actions.class.php public function executedelete(sfwebrequest $request) { $this->person = $this->getroute()->getobject(); $this->forward404unless($this->person); $this->person->delete(); $this->forward( person, index ); // module, action UPMC IRT c by C.Queinnec 37/42 Pagination Configurations Configurer = paraméter statiquement afin de ne pas changer le code. config/ apps/frontend/config/ app.yml # apps/frontend/config/app.yml all: items_per_page: 10 dev: blabla: true Récupération des paramètres avec sfconfig::get( app_items_per_page ) UPMC IRT c by C.Queinnec 38/42 Formulaires pour création public function executeindex(sfwebrequest $request) { $this->pager = new sfdoctrinepager( LoadAverage, sfconfig::get( app_items_per_page )); $this->pager->setquery(doctrine::gettable( LoadAverage ) ->createquery()); $this->pager->setpage($request->getparameter( page, 1)); $this->pager->init(); Les méthodes sur un sfdoctrinepager : getresults() getnbresults() havetopaginate() getpage() getpreviouspage() getnextpage() getlastpage() public function executenew(sfwebrequest $request) { // Sert le formulaire $this->form = new XyzForm(); public function executecreate(sfwebrequest $request) { // Cree l objet en base $this->form = new XyzForm(); $this->processform($request, $this->form); $this->settemplate( new ); protected function processform( sfwebrequest $request, sfform $form) { $form->bind($request->getparameter($form->getname())); if ( $form->isvalid() ) { $xyz = $form->save(); $this->redirect($this->generateurl(xyz_show, $xyz));

11 Formulaires pour modification public function executeedit(sfwebrequest $request) { // Sert le formulaire $this->xyz = $this->getroute()->getobject(); $this->form = new XyzForm($this->xyz); public function executeupdate(sfwebrequest $request) { // Modifie l objet en base $xyz = $this->getroute()->getobject(); $this->form = new XyzForm($xyz); $this->processform($request, $this->form); $this->template( edit ); Conclusions Un excellent cadre de développement! Livre «Symfony : Mieux développer en PHP avec Symfony 1.2 et Doctrine», Fabien Potencier, Hugo Hamon, les Cahiers du Programmeur, Eyrolles, UPMC IRT c by C.Queinnec 41/42 UPMC IRT c by C.Queinnec 42/42

Framework Symfony. (Une introduction) Nicolas de Rugy-Altherre Sylvain Perifel Cristina Sirangelo. L3 Université Paris Diderot

Framework Symfony. (Une introduction) Nicolas de Rugy-Altherre Sylvain Perifel Cristina Sirangelo. L3 Université Paris Diderot Framework Symfony (Une introduction) Nicolas de Rugy-Altherre Sylvain Perifel Cristina Sirangelo L3 Université Paris Diderot Introduction Symfony : framework côté serveur basé sur PHP Intérêts : structuration

Plus en détail

Ruby On Rails. Nelson NUNES/INGENIEURS2000/IR3. Nelson NUNES IR3. Mardi 7 Décembre

Ruby On Rails. Nelson NUNES/INGENIEURS2000/IR3. Nelson NUNES IR3. Mardi 7 Décembre Ruby On Rails Nelson NUNES IR3 Mardi 7 Décembre 2 I. Ruby On Rails A. Définition B. Ruby C. La philosophie D. Architecture MVC E. Les origines de ROR II. Dans le cœur de ROR A. Le MVC dans ROR B. Structure

Plus en détail

PHP. Olivier Aubert 1/24

PHP. Olivier Aubert 1/24 PHP Olivier Aubert 1/24 Introduction PHP = Hypertext PreProcessor Site officiel : http://www.php.net Créé en 1994 par Rasmus Lerdorf (Personal Home Page Tool) 1995 : ajout de la gestion des formulaires

Plus en détail

Services Web SOAP & REST avec symfony

Services Web SOAP & REST avec symfony Services Web SOAP & REST avec symfony RMLL - 6 juillet 2010 Qui suis-je? Hugo HAMON Responsable des formations chez Sensio Labs Coauteur et contributeur d ouvrages Secrétaire Général de l AFUP Webmaster

Plus en détail

Cours HTML/PHP. Cours HTML/PHP. E.Coquery. emmanuel.coquery@liris.cnrs.fr

Cours HTML/PHP. Cours HTML/PHP. E.Coquery. emmanuel.coquery@liris.cnrs.fr Cours HTML/PHP E.Coquery emmanuel.coquery@liris.cnrs.fr Pages Web Pages Web statiques Principe de fonctionnement : L utilisateur demande l accès à une page Web depuis son navigateur. Adresse tapée, clic

Plus en détail

Qu'est-ce que Mysql?

Qu'est-ce que Mysql? Mysql avec php Qu'est-ce que Mysql? Annie Danzart Annie.Danzart@enst.fr http://www.infres.enst.fr/~danzart/mysql/ Qu est-ce que Mysql? Aperçu Langage Le serveur La base de données Interfaces d accès Fonctions

Plus en détail

MySQL 5. Guide de l'administrateur et du développeur. Michael Kofler. Groupe Eyrolles, 2005 pour l édition française, ISBN : 2-212-11633-0

MySQL 5. Guide de l'administrateur et du développeur. Michael Kofler. Groupe Eyrolles, 2005 pour l édition française, ISBN : 2-212-11633-0 MySQL 5 Guide de l'administrateur et du développeur Michael Kofler Groupe Eyrolles, 2005 pour l édition française, ISBN : 2-212-11633-0 Table des matières Avant-propos..............................................

Plus en détail

Applications orientées données (NSY135)

Applications orientées données (NSY135) Applications orientées données (NSY135) 10 Lecture de données Auteurs: Raphaël Fournier-S niehotta et Philippe Rigaux (philippe.rigaux@cnam.fr,fournier@cnam.fr) Département d informatique Conservatoire

Plus en détail

«14_Synthese _PHP_MySQL_cours_4»

«14_Synthese _PHP_MySQL_cours_4» «14_Synthese _PHP_MySQL_cours_4» Maintenant que nous nous sommes connectés à la base de données et y avons mis des informations via un formulaire (cours 13), nous allons voir comment interroger nos tables

Plus en détail

Pages Web statiques. LIF4 - Initiation aux Bases de données : PHP. Pages Web dynamiques. Illustration. Illustration

Pages Web statiques. LIF4 - Initiation aux Bases de données : PHP. Pages Web dynamiques. Illustration. Illustration statiques LIF4 - Initiation aux Bases de données : E.Coquery emmanuel.coquery@liris.cnrs.fr http ://liris.cnrs.fr/ ecoquery Principe de fonctionnement : L utilisateur demande l accès à une page Web depuis

Plus en détail

Institut Supérieur De Gestion De Tunis 3 ème LFIG BAYOUDHI Chaouki

Institut Supérieur De Gestion De Tunis 3 ème LFIG BAYOUDHI Chaouki Exemple JSF EJB et Bean géré I. Enoncé : Cet exemple est une petite application web proposant deux pages web : L une qui affiche un formulaire afin de pouvoir ajouter un livre (AjoutLivre.xhtml), L autre

Plus en détail

SENSIO LABS. Formation Maîtrise de Symfony et Doctrine Niveau 1. Sensio. 92-98 boulevard Victor Hugo. 92115 Clichy

SENSIO LABS. Formation Maîtrise de Symfony et Doctrine Niveau 1. Sensio. 92-98 boulevard Victor Hugo. 92115 Clichy SENSIO LABS Formation Maîtrise de Symfony et Doctrine Niveau 1 Sensio 92-98 boulevard Victor Hugo 92115 Clichy 1 SOMMAIRE Introduction... 3 Le framework symfony... 3 Objectifs de la formation... 3 Public

Plus en détail

Chapitre 1 Installer MySQL 5 21

Chapitre 1 Installer MySQL 5 21 Chapitre 1 Installer MySQL 5 21 1.1. Les outils nécessaires... 22 1.2. Télécharger et installer le serveur MySQL... 22 Télécharger la dernière version... 22 Lancer l installation sous Windows... 23 Lancer

Plus en détail

FONCTIONS DE TRAITEMENT} COUNT

FONCTIONS DE TRAITEMENT} COUNT Nom Prénom Promotion Date Buhl Damien Année 1 Groupe 2 21 Janvier 2007 CER Prosit n 22 Mots-Clés : - Requête/Langage SQL Le langage SQL (Structured Query Language) est un langage de requêtes, il permet

Plus en détail

Java Persistence Api. 1. Introduction. 2. Un premier exemple. 3. L application. benoit.charroux@efrei.fr

Java Persistence Api. 1. Introduction. 2. Un premier exemple. 3. L application. benoit.charroux@efrei.fr Java Persistence Api Cet article décrit une application qui illustre comment la sauvegarde d un graphe d objets peut être réalisé en Java Standard Edition via Java Persistence Api. 1. Introduction Java

Plus en détail

Modification des données stockées dans une base. LIF4 - Initiation aux Bases de données : SQL - 3. Exemple. Insertion. Insertion utilisant une requête

Modification des données stockées dans une base. LIF4 - Initiation aux Bases de données : SQL - 3. Exemple. Insertion. Insertion utilisant une requête Modification des données stockées dans une base LIF4 - Initiation aux Bases de données : SQL - 3 E.Coquery emmanuel.coquery@liris.cnrs.fr http ://liris.cnrs.fr/ ecoquery La modification s effectue par

Plus en détail

Le mapping objet relationnel. Introduction au mapping objet relationnel avec Nhibernate Cyril GRAUFFEL IR3 2009/2010

Le mapping objet relationnel. Introduction au mapping objet relationnel avec Nhibernate Cyril GRAUFFEL IR3 2009/2010 Le mapping objet relationnel Introduction au mapping objet relationnel avec Nhibernate Cyril GRAUFFEL IR3 2009/2010 Plan de présentation 1. Le modèle relationnel et le modèle objet 2. Le Mapping Objet

Plus en détail

PHP 6. www.fenetresurtoile.com PHP 6. Jean-François Ramiara. FAD Réseau Pyramide 14/01/2013 Toulouse. Copyright J.F. Ramiara Tous droits réservés

PHP 6. www.fenetresurtoile.com PHP 6. Jean-François Ramiara. FAD Réseau Pyramide 14/01/2013 Toulouse. Copyright J.F. Ramiara Tous droits réservés www.fenetresurtoile.com Jean-François Ramiara FAD Réseau Pyramide 14/01/2013 Toulouse 1 www.fenetresurtoile.com Sommaire Introduction Ajout avec SQL Modification avec SQL Suppression avec SQL Mises à jour

Plus en détail

Persistance en Php. Note : les problèmes d accès concurrents, de sécurité et de login sont laissés de côté.

Persistance en Php. Note : les problèmes d accès concurrents, de sécurité et de login sont laissés de côté. Persistance en Php Objectif : faire un site pour gérer des articles par catégorie. Chaque catégorie a un nom, chaque catégorie est constitué d articles (titre, auteur, texte), un article est dans une seule

Plus en détail

Développement Web. Jean-Michel Richer jean-michel.richer@univ-angers.fr http://www.info.univ-angers.fr/pub/richer. 24 janvier 2011

Développement Web. Jean-Michel Richer jean-michel.richer@univ-angers.fr http://www.info.univ-angers.fr/pub/richer. 24 janvier 2011 1 / 56 Développement Web Le modèle MVC Jean-Michel Richer jean-michel.richer@univ-angers.fr http://www.info.univ-angers.fr/pub/richer 24 janvier 2011 2 / 56 Objectif Objectif du cours Se familiariser avec

Plus en détail

CREATION WEB DYNAMIQUE

CREATION WEB DYNAMIQUE CREATION WEB DYNAMIQUE IV ) MySQL IV-1 ) Introduction MYSQL dérive directement de SQL (Structured Query Language) qui est un langage de requêtes vers les bases de données relationnelles. Le serveur de

Plus en détail

Tp2 Emacs Développement Web

Tp2 Emacs Développement Web Tp2 Emacs Développement Web Les indications ci-dessous donnent les grandes lignes du développement. 1/ Evenement Ajax Jquery: Le code javascript jquery suivant permet d afficher un message dans un span

Plus en détail

Programmation orientée objet en langage JAVA

Programmation orientée objet en langage JAVA Connexion à une base de données avec JDBC Programmation orientée objet en langage JAVA Connexion à une base de données avec JDBC Claude Duvallet Université du Havre UFR Sciences et Techniques 25 rue Philippe

Plus en détail

Le framework Symfony2

Le framework Symfony2 Le framework Symfony2 Historique et définition Framework: cadre de travail Objectif: améliorer la productivité des développeurs (se concentrer sur les choses importantes), structurer l application, accélère

Plus en détail

Interfaçage avec une base de données

Interfaçage avec une base de données Interfaçage avec une base de données Principe PHP propose de nombreux outils permettant de travailler avec la plupart des SGBD Oracle, Sybase, Microsoft SQL Server, PostgreSQL ou encore MySQL Php fournit

Plus en détail

PHP. Bertrand Estellon. 26 avril 2012. Aix-Marseille Université. Bertrand Estellon (AMU) PHP 26 avril 2012 1 / 214

PHP. Bertrand Estellon. 26 avril 2012. Aix-Marseille Université. Bertrand Estellon (AMU) PHP 26 avril 2012 1 / 214 PHP Bertrand Estellon Aix-Marseille Université 26 avril 2012 Bertrand Estellon (AMU) PHP 26 avril 2012 1 / 214 SQLite et PDO Base de données SQLite et PDO SQLite écrit les données relatives à la base dans

Plus en détail

«Anatomie» d une application web Servlets - JDBC

«Anatomie» d une application web Servlets - JDBC «Anatomie» d une application web Servlets - JDBC Patrick REIGNIER - Philippe GENOUDUJF Février 2005 1 L application histogramme de notes HistoServlet HistoServlet HistogramModel HistogramModel (objet (objet

Plus en détail

CakePHP. Référence: http://book.cakephp.org/. CakePHP. Framework Open Source de développement pour PHP

CakePHP. Référence: http://book.cakephp.org/. CakePHP. Framework Open Source de développement pour PHP CakePHP Référence: http://book.cakephp.org/. Introduction à CakePHP 1 CakePHP Framework Open Source de développement pour PHP Environnement de développement rapide d'applications (RAD sur le web. Supporte

Plus en détail

E5SL : PRODUCTION ET FOURNITURE DE SERVICES. Durée : 4 heures Coefficient : 5 CAS SUPMASTER. Éléments de correction

E5SL : PRODUCTION ET FOURNITURE DE SERVICES. Durée : 4 heures Coefficient : 5 CAS SUPMASTER. Éléments de correction BTS SERVICES AUX ORGANISATIONS SESSION E5SL : PRODUCTION ET FOURNITURE DE SERVICES Durée : 4 heures Coefficient : 5 CAS SUPMASTER Éléments de correction Ce corrigé comporte 8 pages numérotées de 1/8 à

Plus en détail

Short-Circuit Introduction Spring JPA, JTA, DBConnectionPool. Cours Spring Data

Short-Circuit Introduction Spring JPA, JTA, DBConnectionPool. Cours Spring Data Cours Spring Data 1 Présentation Générale - Spring Data est un robuste framework de l écosystème de Spring qui se compose de nombreux modules offrant d accéder des solutions de données alternatives comme

Plus en détail

Programmation MySQL/PHP. Programmation MySQL/PHP p.1/19

Programmation MySQL/PHP. Programmation MySQL/PHP p.1/19 Programmation MySQL/PHP Programmation MySQL/PHP p.1/19 CGI et bases de données Principe : création de documents à partir d une BD MySQL se charge du stockage, de la protection des données, de l interface

Plus en détail

PHP /MySQL Interface d'accès aux BDDs PDO. Youssef CHAHIR

PHP /MySQL Interface d'accès aux BDDs PDO. Youssef CHAHIR PHP /MySQL Interface d'accès aux BDDs PDO Youssef CHAHIR 1 PLAN Architecture Interface phpmyadmin Créer une interface PHP/MySQL : Établir une connexion Exécuter une requête Gérer les erreurs Exploiter

Plus en détail

Classes et objets en PHP. PHP OO et Pear DB. Classe, attributs, méthodes. Classes et objets en PHP (2) Classe, attributs, méthodes (3)

Classes et objets en PHP. PHP OO et Pear DB. Classe, attributs, méthodes. Classes et objets en PHP (2) Classe, attributs, méthodes (3) Classes et objets en PHP PHP OO et Pear DB Olivier Perrin IUT Nancy-Charlemagne Département Informatique Université Nancy 2 Une classe PHP regroupe des variables d instance, représentés par des variables

Plus en détail

Conception de sites web : examen final

Conception de sites web : examen final Conception de sites web : examen final Jean-Baptiste.Vioix@u-bourgogne.fr 17 février 2006 Nom : Prénom : 1 Questions de cours (4 pts) Pour les questions de cours, rayez la ou les réponses fausses. 1.1

Plus en détail

Bases de Données Relationnelles. SQL Le langage de définition des données de SQL

Bases de Données Relationnelles. SQL Le langage de définition des données de SQL Bases de Données Relationnelles SQL Le langage de définition des données de SQL Introduction SQL : Structured Query Language SQL est normalisé SQL 2: adopté (SQL 92) SQL 3: adopté (SQL 99) Standard d'accès

Plus en détail

Symfony 2. 1.Définition de symfony 2. 2.Installation. 3.Structure. 4.Symfony et les commandes

Symfony 2. 1.Définition de symfony 2. 2.Installation. 3.Structure. 4.Symfony et les commandes Symfony 2 Sommaire : 1.Définition de symfony 2 2.Installation 3.Structure 4.Symfony et les commandes 5.Le fonctionnement : le routeur (les url), les bundles, twig(templates) 6.L architecture de symfony2

Plus en détail

CHARLOIS SIGAUD AGNAN Nils Vincent Diane PROJET 04 - PLATEFORME DE PROJET ZEND ET SYMFONY

CHARLOIS SIGAUD AGNAN Nils Vincent Diane PROJET 04 - PLATEFORME DE PROJET ZEND ET SYMFONY CHARLOIS SIGAUD AGNAN Nils Vincent Diane PROJET 04 - PLATEFORME DE PROJET ZEND ET SYMFONY Installation de Symfony : Paquet à installer : - php5 - php5-pgsql - postgresql - apache2 Prérequis au niveau

Plus en détail

Analyse lexicale 2014-2015

Analyse lexicale 2014-2015 Analyse (lexicale, syntaxique) L3 MIAGE Analyse lexicale Université de Lille, France 2014-2015 1 Rappels Rôle de l analyse lexicale Outils 2 Mise en oeuvre Lexème Vers l analyseur syntaxique Codage d un

Plus en détail

Jean-Michel Richer jean-michel.richer@univ-angers.fr http://www.info.univ-angers.fr/pub/richer. L3 Pro Informatique 2010-2011

Jean-Michel Richer jean-michel.richer@univ-angers.fr http://www.info.univ-angers.fr/pub/richer. L3 Pro Informatique 2010-2011 1 / 32 Développement Web - JDBC Jean-Michel Richer jean-michel.richer@univ-angers.fr http://www.info.univ-angers.fr/pub/richer L3 Pro Informatique 2010-2011 2 / 32 Plan Plan 1 Préambule 2 Utilisation de

Plus en détail

Exposer des services web SOAP et REST

Exposer des services web SOAP et REST Exposer des services web SOAP et REST RMLL - 6 juillet 2010 Qui suis-je? Hugo HAMON (@hhamon) Responsable des formations chez Sensio Labs Coauteur et contributeur d ouvrages Secrétaire Général de l AFUP

Plus en détail

DOSSIER D'ACTIVITES SUR LE PHP N 07 Supprimer des données d'une base de données

DOSSIER D'ACTIVITES SUR LE PHP N 07 Supprimer des données d'une base de données DOSSIER D'ACTIVITES SUR LE PHP N 07 Supprimer des données d'une base de données Objectifs : Apprendre à l apprenant à lancer un serveur local «Apache» Apprendre à l'apprenant à lancer un serveur MySQL

Plus en détail

JDBC et objet-relationnel

JDBC et objet-relationnel Types de données de SQL3 JDBC et objet-relationnel Université de Nice - Sophia Antipolis Version 1.6.4 5/11/11 Richard Grin JDBC supporte les types suivants de SQL3 qui sont des ouvertures vers le relationnelobjet

Plus en détail

Applications orientées données (NSY135)

Applications orientées données (NSY135) Applications orientées données (NSY135) 11 Le langage HQL Auteurs: Raphaël Fournier-S niehotta et Philippe Rigaux (philippe.rigaux@cnam.fr,fournier@cnam.fr) Département d informatique Conservatoire National

Plus en détail

AJAX AJAX. Asynchronous JavaScript And XML. Technologie pour créer des pages web interactives Basées sur XML, HTML et JavaScript

AJAX AJAX. Asynchronous JavaScript And XML. Technologie pour créer des pages web interactives Basées sur XML, HTML et JavaScript AJAX Ajax 1 AJAX Asynchronous JavaScript And XML. Technologie pour créer des pages web interactives Basées sur XML, HTML et JavaScript Utilise: HTML pour le marquage XML pour représenter les résultats

Plus en détail

Programmation Web Avancée php

Programmation Web Avancée php 1 Programmation Web Avancée php Sur 3-4 séances Objet, BD, Fichier, XML «Modules» Séance 1 : Objet, BD Principes 2 langage : PHP (html preprocessor) un pré processeur de HTTP typage dynamique orienté objet

Plus en détail

Chaker ALLAOUI chaker.allaoui@gmail.com WEBSERVICE API REST SYMFONY 2

Chaker ALLAOUI chaker.allaoui@gmail.com WEBSERVICE API REST SYMFONY 2 Chaker ALLAOUI chaker.allaoui@gmail.com WEBSERVICE API REST SYMFONY 2 TABLE DES MATIERES Contenu Présentation 1 Technologies 2 Installation des bundles 3 Configuration des bundles 4 Configuration de Symfony

Plus en détail

PHP /MySQL Interface d'accès aux BDDs PDO. Youssef CHAHIR

PHP /MySQL Interface d'accès aux BDDs PDO. Youssef CHAHIR PHP /MySQL Interface d'accès aux BDDs PDO Youssef CHAHIR 1 PLAN Architecture Créer une interface PHP/MySQL : Établir une connexion Exécuter une requête Gérer les erreurs Exploiter les résultats de la requête

Plus en détail

Formation Symfony 2, fondamentaux et avancé

Formation Symfony 2, fondamentaux et avancé L institut de formation continue des professionnels du Web Formation Symfony 2, fondamentaux et avancé Référence formation : Durée : Prix conseillé : SF2 5 jours (35 heures) 2 600 HT (hors promotion ou

Plus en détail

Développement du CMS Ocari avec Symfony

Développement du CMS Ocari avec Symfony Développement du CMS Ocari avec Symfony Sébastien ANGELE Jérôme MACIAS Titre présentation Conférencier Les besoins Un CMS pour faire quoi? Gérer des contenus Gérer des médias Gérer des homes Gérer des

Plus en détail

1. EDI... 2 2. INSTALLATION DE LARAVEL... 2 3. CREER UN NOUVEAU PROJET LARAVEL... 2

1. EDI... 2 2. INSTALLATION DE LARAVEL... 2 3. CREER UN NOUVEAU PROJET LARAVEL... 2 1 Laravel 5 J. ROMAGNY Table des matières 1. EDI... 2 2. INSTALLATION DE LARAVEL... 2 3. CREER UN NOUVEAU PROJET LARAVEL... 2 A. PACKAGES POUR LARAVEL... 3 B. CONFIGURER LE SITE... 3 C. AFFICHER SON SITE...

Plus en détail

Cours n 6 SQL : Langage de définition des données (LDD)

Cours n 6 SQL : Langage de définition des données (LDD) Cours n 6 SQL : Langage de définition des données (LDD) Chantal Reynaud Université Paris X - Nanterre UFR SEGMI - IUP MIAGE Cours de Systèmes de Gestion de Données Licence MIAGE 2003/2004 1 Plan I. Langage

Plus en détail

Web dynamique. Techniques, outils, applications. (Partie C)

Web dynamique. Techniques, outils, applications. (Partie C) Web dynamique Techniques, outils, applications (Partie C) Nadir Boussoukaia - 2006 1 SOMMAIRE 1. MySQL et PHP (20 min) 2. SQL (petits rappels) (20 min) 2 MySQL et PHP Synthèse 3 MySQL et PHP SGBD MySQL

Plus en détail

Cours: BD et Environnement Distribuées

Cours: BD et Environnement Distribuées UNIVERSITÉ DE BOURGOGNE UFR Sciences et Techniques Cours: BD et Environnement Distribuées TP 4 - Mapping Objet Relationnel Préparé par: MATTA Elie et al. Copyright 2010-2011, eliematta.com. All rights

Plus en détail

DQL Doctrine Query Language UP Web Framework PHP

DQL Doctrine Query Language UP Web Framework PHP DQL Doctrine Query Language UP Web Framework PHP Année universitaire 2014-2015 Repository Les Repository servent à récupérer et à manipuler les entités. Ces services utilisent un Entity Manager: 2 techniques

Plus en détail

Veille technologique Symfony 2

Veille technologique Symfony 2 Veille technologique Symfony 2 Introduction : Symfony2 est un Framework PHP en MVC qui a pour objectif d'accélérer les développements. Il impose également un certain nombre de bonne pratique à respecter

Plus en détail

Jusqu à 14 h : Open Questions! On vous explique ce que vous n avez pas compris lors de la première formation.

Jusqu à 14 h : Open Questions! On vous explique ce que vous n avez pas compris lors de la première formation. Bienvenue! Jusqu à 14 h : Open Questions! On vous explique ce que vous n avez pas compris lors de la première formation. Téléchargez les logiciels nécessaires pour cette formation : http ://formation-web.via.ecp.fr

Plus en détail

PHP & BD. PHP & Bases de données. Logiciels & matériels utilisés. Bases de données et Web

PHP & BD. PHP & Bases de données. Logiciels & matériels utilisés. Bases de données et Web PHP & Bases de données La quantité de données utilisée par certains sites web nécessite l'utilisation d'une base de données Il faut donc disposer d'un SGBD (mysql, postgresql, oracle, ) installé sur un

Plus en détail

Android API de Persistance. James Douglass Lefruit Ingénieur de Recherche, INRIA Grenoble

Android API de Persistance. James Douglass Lefruit Ingénieur de Recherche, INRIA Grenoble Android API de Persistance James Douglass Lefruit Ingénieur de Recherche, INRIA Grenoble Android Les Préférences SharedPreferences Stockage SQLite sur Android Introduction Générale à SQLite Les API SQLite

Plus en détail

Formation PHP/MySQL. Pierre PATTARD. Avril 2005

Formation PHP/MySQL. Pierre PATTARD. Avril 2005 Formation PHP/MySQL Pierre PATTARD Julien BENOIT Avril 2005 Le PHP Langage interprété, côté serveur pages interprétées par le serveur web pas de compilation, code éditable avec un bloc notes. aucune différences

Plus en détail

Bases de données Cours 7 : Modèle relationnel-objet

Bases de données Cours 7 : Modèle relationnel-objet -relationnel Cours 7 : Modèle relationnel-objet ESIL Université de la méditerranée Odile.Papini@esil.univ-mrs.fr http://pages-perso.esil.univmed.fr/ papini/ -relationnel Plan du cours 1 Introduction 2

Plus en détail

M3202. structuré son developpement avec MVC

M3202. structuré son developpement avec MVC M3202 structuré son developpement avec MVC FRAMEWORK et MVC ou ça? RAPPEL LES FRAMEWORKS Un framework est un espace de travail modulaire. C'est un ensemble de bibliothèques et de conventions permettant

Plus en détail

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

La persistance des données dans les applications : DAO, JPA, Hibernate... COMPIL 2010 francois.jannin@inp-toulouse.fr 1 La persistance des données dans les applications : DAO, JPA, Hibernate... COMPIL 2010 francois.jannin@inp-toulouse.fr 1 Plan 1. Généralités sur la persistance des données dans les applications 2. La connection

Plus en détail

MODIFICATIONS ET CREATIONS OSCOMMERCE POUR ICI RELAIS

MODIFICATIONS ET CREATIONS OSCOMMERCE POUR ICI RELAIS MODIFICATIONS ET CREATIONS OSCOMMERCE POUR ICI RELAIS Objectif : Le but de ce document est d expliquer les fonctions de chaque nouveau fichier propre au module de livraison ICI relais. Il reprend également

Plus en détail

Cours 10 Formulaires Web pour saisie de données dans une base de données relationnelle avec PHP (partie 2 de 2)

Cours 10 Formulaires Web pour saisie de données dans une base de données relationnelle avec PHP (partie 2 de 2) École de bibliothéconomie et des sciences de l information SCI6306 Bases de données documentaires Cours 10 Formulaires Web pour saisie de données dans une base de données relationnelle avec PHP (partie

Plus en détail

COMPTE RENDU M. Mouad EL MERCHICHI CRJJ GB. Ceci est un résumé du travail effectué dans les TP concernant les scriptlets et le modèle MVC.

COMPTE RENDU M. Mouad EL MERCHICHI CRJJ GB. Ceci est un résumé du travail effectué dans les TP concernant les scriptlets et le modèle MVC. COMPTE RENDU M. Mouad EL MERCHICHI CRJJ GB Ceci est un résumé du travail effectué dans les TP concernant les scriptlets et le modèle MVC. Page 0 Sommaire Introduction... 2 TP I : Scriptlets et Actions...

Plus en détail

Développer mieux en PHP avec. Forum PHP AFUP 2010

Développer mieux en PHP avec. Forum PHP AFUP 2010 Développer mieux en PHP avec Forum PHP AFUP 2010 Qui suis- je? v Hugo HAMON (@hhamon) v v Responsable des formations à 8 ans de PHP v Secrétaire de l AFUP v Auteur du site Apprendre-PHP.com v Coauteur

Plus en détail

Plan de la scéance. Modélisation et conception de bases de données. Que doit-on concevoir? L3Pro SCT Bases de données et programmation

Plan de la scéance. Modélisation et conception de bases de données. Que doit-on concevoir? L3Pro SCT Bases de données et programmation Modélisation et conception de bases de données L3Pro SCT Bases de données et programmation Mathieu Sassolas IUT de Sénart Fontainebleau Département Informatique Année 2015-2016 Plan de la séance 3 2 /

Plus en détail

TD2 : PHP «avancé» V3.0.0

TD2 : PHP «avancé» V3.0.0 TD2 : «avancé» V3.0.0 Cette œuvre est mise à disposition selon les termes de la licence Creative Commons Attribution Pas d'utilisation Commerciale Partage à l'identique 3.0 non transposé. Document en ligne

Plus en détail

TP n o 14 : Bases de données, première partie

TP n o 14 : Bases de données, première partie TP n o 14 : Bases de données, première partie I Introduction Dans ce TP nous allons effectuer des opérations élementaires sur une base de données ne comportant qu une seule table. Lors de la prochaine

Plus en détail

Application GSB_FRAIS avec Symfony2

Application GSB_FRAIS avec Symfony2 Application GSB_FRAIS avec Symfony2 Description du thème Propriétés Description Intitulé long Formation concernée Matière Présentation Notions Pré-requis Outils Mots-clés Durée Auteur(es) Gestion des frais

Plus en détail

Inf340 Systèmes d information. Deuxième site : approche MVC

Inf340 Systèmes d information. Deuxième site : approche MVC Inf340 Systèmes d information Deuxième site : approche MVC Objectifs Objectif : Reprendre le site précédent en utilisant le patron de conception Modèle Vue Contrôleur. Comprendre l apport d un framework

Plus en détail

Exercices et corrections. Licence QCI - module O21

Exercices et corrections. Licence QCI - module O21 Exercices et corrections Licence QCI - module O21 Exercice 1 Ecrivez le squelette d une page avec les caractéristiques suivantes - encodage : utf-8 - titre de la page : première page XHTML - auteur : vous

Plus en détail

Symfony Live 2009 Etude de Cas : Mise en place d un générateur de contenu et de flux XML à l aide des «tasks»

Symfony Live 2009 Etude de Cas : Mise en place d un générateur de contenu et de flux XML à l aide des «tasks» Symfony Live 2009 Etude de Cas : Mise en place d un générateur de contenu et de flux XML à l aide des «tasks» sflive Event 09 [ The Shopper Activation Agency 1 ] PRESENTATION sflive Event 09 2 A propos

Plus en détail

Optimisation. Bases de Données. Année 2007-08

Optimisation. Bases de Données. Année 2007-08 Optimisation Bases de Données Année 2007-08 Les index Les index sont utilisés pour accélérer l accès aux données. fonction de hachage qui permet de retrouver rapidement un ou des enregistrements les clés

Plus en détail

Table des matières. TP Ajax. Séquence 1 L'objet XMLHttpRequest...2 Séquence 2 L'API jquery...3 Séquence 3 XML...4 Séquence 4 L'auto complétion...

Table des matières. TP Ajax. Séquence 1 L'objet XMLHttpRequest...2 Séquence 2 L'API jquery...3 Séquence 3 XML...4 Séquence 4 L'auto complétion... Table des matières Séquence 1 L'objet XMLHttpRequest...2 Séquence 2 L'API jquery...3 Séquence 3 XML...4 Séquence 4 L'auto complétion...7 Bibliographie : http://fr.wikipedia.org/wiki/asynchronous_javascript_and_xml

Plus en détail

CREATE TABLE `blog` ( `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY, `title` VARCHAR( 128 ) NOT NULL,

CREATE TABLE `blog` ( `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY, `title` VARCHAR( 128 ) NOT NULL, Créer un blog en 20 mn Tout d abord, créer la base de données qui contiendra le blog Avec phpmyadmin définir une base de données de nom blog Définir une table de nom entries Dans cette table, on créera

Plus en détail

Modélisation et bases de données

Modélisation et bases de données Ce tutoriel vous indique comment modéliser et générer une base de données Access puis MySQL avec le logiciel. Un tableau de correspondance des principaux types de donnée est présenté à la fin du support.

Plus en détail

Plusieurs façons de communiquer AJAX? Communication, manière facile. AJAX en jquery

Plusieurs façons de communiquer AJAX? Communication, manière facile. AJAX en jquery Programmation web AJAX Jean-Christophe Dubacq IUT de Villetaneuse S3 2013 AJAX A Jean-Christophe Dubacq (IUTV) Programmation web S3 2013 1 / 33 Le modèle classique Jean-Christophe Dubacq (IUTV) Programmation

Plus en détail

Client riche et performance serveur avec PHP 5

Client riche et performance serveur avec PHP 5 Anaska services : Les experts PHP français 1 Client riche et performance serveur avec PHP 5 Par Cyril PIERRE de GEYER Co-auteur du livre PHP 5 avancé Architecte PHP / Anaska Anaska services : Les experts

Plus en détail

Les triggers. Introduction 1/18. Objectifs. I Utiliser à bon escient le paramétrage des triggers :

Les triggers. Introduction 1/18. Objectifs. I Utiliser à bon escient le paramétrage des triggers : 1/18 2/18 Anne-Cécile Caron Licence MIAGE - Bases de Données 2015-2016 Objectifs Après ce cours, les TD et TP correspondants, vous devez être capables de I Ecrire en PL/SQL des triggers liés aux tables.

Plus en détail

Bilan de l'u+lisa+on du Framework Symfony2

Bilan de l'u+lisa+on du Framework Symfony2 Bilan de l'u+lisa+on du Framework Symfony2 pour la refonte complète de 2 applica+ons Web 23/10/12 Jus+ne Yuan et Serge Dû (LAL Orsay) 1 Contexte: les applis web au labo Importante base classique PHP MySQL

Plus en détail

Stockage du fichier FITS dans une table MySQL Nous utiliserons des types de données spéciaux, qui sont les BLOBS (binary large objects).

Stockage du fichier FITS dans une table MySQL Nous utiliserons des types de données spéciaux, qui sont les BLOBS (binary large objects). Stockage des fichiers FITS du téléscope MISOLFA dans une base de donnée MySQL avec PHP Auteur : Erwan Simon CNRS UMR 6202 O.C.A Département Cassiopée Le 24/05/2009, Le but de ce document est de donner

Plus en détail

Sites web MVC Damien Nouvel

Sites web MVC Damien Nouvel Sites web MVC Plan Architecture MVC Vues / interface Contrôleur / application 2 / 17 Plan Architecture MVC Vues / interface Contrôleur / application 3 / 17 Architecture MVC MVC Méthode de conception d'interface

Plus en détail

module SIN21 Rendre un syste me communicant Analyse UML et algorithmie 1 Modification du cahier des charges

module SIN21 Rendre un syste me communicant Analyse UML et algorithmie 1 Modification du cahier des charges Module SIN221 Rendre un syste me communicant Analyse UML et algorithmie Objectifs : Modifier des diagrammes UML suite à la modification du cahier des charges. Caractériser et valider une classe en C++.

Plus en détail

Système d exploitation Partie I

Système d exploitation Partie I Sécurité des Serveurs Windows 2008/2003 Système d exploitation Windows IIS 7.0 / IIS 6.0 Serveur Web Ivan Madjarov, IUT-R&T, Kourou,2010 Les objectifs Cette présentation a pour objectif de démontrer qu'on

Plus en détail

PHP OO et Pear DB. Olivier Perrin IUT Nancy-Charlemagne Département Informatique Université Nancy 2. Olivier.Perrin@loria.fr

PHP OO et Pear DB. Olivier Perrin IUT Nancy-Charlemagne Département Informatique Université Nancy 2. Olivier.Perrin@loria.fr PHP OO et Pear DB Olivier Perrin IUT Nancy-Charlemagne Département Informatique Université Nancy 2 Olivier.Perrin@loria.fr Classes et objets en PHP Une classe PHP regroupe des variables d instance, représentés

Plus en détail

Développement Partie Cliente

Développement Partie Cliente ISI 1022 : Jean-Noël Sorenti. Année 2002/2003 Développement Partie Cliente ISI 1022 : 1 ISI 1022 : Développement Partie Cliente Le développement partie cliente concerne tout développement étant interprété

Plus en détail

Travaux pratiques de M2105 Web dynamique

Travaux pratiques de M2105 Web dynamique Travaux pratiques de M2105 Web dynamique L objectif des séances de TP du module M2105 est de créer un mini site web d annuaire permettant à différents utilisateurs de gérer leurs contacts. Les informations

Plus en détail

SQLite pour Android. Construction de la base de données

SQLite pour Android. Construction de la base de données SQLite pour Android On veut, dans ce TP, construire une application Android qui permet de gérer des contacts (essentiellement un nom associé à un numéro de téléphone). Ces contacts seront mis dans une

Plus en détail

Formation Magento 2 : Back End

Formation Magento 2 : Back End L institut de formation continue des professionnels du Web Formation Magento 2 : Back End Référence formation : Durée : Prix conseillé : MAG2B 5 jours (35 heures) 2 500 HT (hors promotion ou remise particulière)

Plus en détail

2.Créer les pages PHP pour consulter et mettre à jour la table annuaire

2.Créer les pages PHP pour consulter et mettre à jour la table annuaire Université Nice Sophia Antipolis 2007-2008 LPSIL UE SIL-TC3-P1 Module: OSI, INTERNET ET PROGRAMMATION WEB TP 5 Annexe- Utilisation d ORACLE Objectif : Base de Donnée sous ORACLE et PHP Correction : la

Plus en détail

PHP 5. simplexml. A. Belaïd 1

PHP 5. simplexml. A. Belaïd 1 PHP 5 simplexml A. Belaïd 1 Introduction Dans les versions précédentes de PHP, il n y avait aucun outil permettant de manipuler simplement des fichiers XML Dans PHP 5, on trouve un mode, appelé, SimpleXML

Plus en détail

MVC / Les Tags JSP et JSTL

MVC / Les Tags JSP et JSTL MVC / Les Tags JSP et JSTL A.-E. Ben Salem LRDE and LIP6 17 Octobre 2011 1 / 18 Plan 1 Architecture MVC 2 Rappel JSP 3 JSTL (JSP Standard Tag Library) 4 Tags JSP pour gérer les Beans 5 Tags JSP d action

Plus en détail

Cours 7 : Langage de définition, manipulation et contrôle des données

Cours 7 : Langage de définition, manipulation et contrôle des données Cours 7 : Langage de définition, manipulation et contrôle des données Objets d une base de données Dans un schéma Tables, vues Index, clusters, séquences, synonymes Packages, procédures, fonctions, déclencheurs

Plus en détail

Apprendre à développer un site web avec PHP et MySQL Exercices pratiques et corrigés (3ième édition)

Apprendre à développer un site web avec PHP et MySQL Exercices pratiques et corrigés (3ième édition) Introduction 1. Objectif de l'ouvrage 15 2. Fonctionnement d un site web 16 Utilisation d EasyPHP 1. Introduction 19 2. Installation d'easyphp 20 3. Prise en main d EasyPHP 20 4. Création d une première

Plus en détail

Introduction à PHP. PHP et SGBD : un exemple avec Mysql. 1 er mai 2015. IUT de Fontainebleau. Introduction Mysql API mysqli Requêtes préparées

Introduction à PHP. PHP et SGBD : un exemple avec Mysql. 1 er mai 2015. IUT de Fontainebleau. Introduction Mysql API mysqli Requêtes préparées PHP et SGBD : un exemple avec IUT de Fontainebleau 1 er mai 2015 Sommaire 1 Introduction 2 3 4 Sommaire 1 Introduction 2 3 4 Problématique Sites dynamiques "Informations dynamiques". Comment la gérer,

Plus en détail

L1 Option Programmation Web côté Serveur - Contrôle continu n 1

L1 Option Programmation Web côté Serveur - Contrôle continu n 1 L Option Programmation Web côté Serveur - Contrôle continu n Veuillez noircir les cases correspondantes à votre numéro d étudiant ( case/colonne). Si votre N est, il faut noircir le dans la ère colonne,

Plus en détail

PHP et mysql. Code: php_mysql. Olivier Clavel - Daniel K. Schneider - Patrick Jermann - Vivian Synteta Version: 0.9 (modifié le 13/3/01 par VS)

PHP et mysql. Code: php_mysql. Olivier Clavel - Daniel K. Schneider - Patrick Jermann - Vivian Synteta Version: 0.9 (modifié le 13/3/01 par VS) PHP et mysql php_mysql PHP et mysql Code: php_mysql Originaux url: http://tecfa.unige.ch/guides/tie/html/php-mysql/php-mysql.html url: http://tecfa.unige.ch/guides/tie/pdf/files/php-mysql.pdf Auteurs et

Plus en détail

Gestion Bibliothèque. Résumé

Gestion Bibliothèque. Résumé Gestion Bibliothèque Résumé Ces travaux seront réalisés dans le cadre du cours Web Services Miage NTDP afin de permettre aux étudiants d assimiler les concepts théoriques vus en cours. L idée est de développer

Plus en détail

Base de données. Ensuite, on peut utiliser les fonctions length et setlength pour respectivement lire et changer la taille du tableau.

Base de données. Ensuite, on peut utiliser les fonctions length et setlength pour respectivement lire et changer la taille du tableau. Base de données Nouvelles notions Voici quelques nouvelles fonctionnalités du langage dont vous aurez à vous servir. Prenez le temps de bien comprendre et tester les exemples. Tableaux à taille dynamique

Plus en détail