Technologie Web M1 Miage 2016-2017

De $1

Version de 11:45, 23 Nov 2024

cette version.

Revenir à liste des archives.

Voir la version actuelle

Introduction

Séance 1 : rappels sur l'histoire du Web et des technologies Web, introduction à la technologie JavaEE

Rappels historiques (les parties non vues en cours sont à voir à la maison) :

    Introduction aux technologies du Web 
    • Ici une vidéo (en anglais, activer les sous-titres) qui retrace l'histoire du Web et des technologies, aussi des services marquants que nous connaissons aujourd'hui, avec leur date d'apparition et de nombreuses anecdotes : 

       
  • Le Web ce n'est pas l'Internet (c'est entre autre sa couche hypertexte, et bien plus...) : cette vidéo retrace "histoire de l'internet de 1957 à nos jours", n'oubliez pas d'activer les sous-titres (petite flèche vers le haut, en bas à droite du lecteur) :

     
  • Vidéo pour fêter l'anniversaire de Tim Berners Lee (anglais), linventeur du web, retrace à travers son parcours, l'histoire du Web : , penser à activer les sous-titres.
     
  • Du Web aux wikis : une histoire des outils collaboratif (par Michel Buffa) : pour bien comprendre l'évolution du web dans sa phase 1993 jusqu''à 2005, soit l'apparition du Web 2.0 appelé aussi le "web social" dont il reste de grosses traces aujourd'hui (facebook, twitter, wikis, blogs, etc). Cet article retrace en particulier les premiers pas de l'internet en France, la naissance du Web et son évolution vers un Web servant non pas à relier des documents entre eux, mais des personnes, des objets, etc. Pour ceux que l'histoire du Web intéresse.
     
  • Le protocole HTTP au coeurs du Web et des Web Services : ProtocoleHTTP.pdf

Rappels HTML/CSS/JS

Obligatoire: inscription au MOOC HTML5 part 1!

Michel Buffa est l'auteur de deux MOOCs sur HTML5 : HTML5 part 1 et HTML5 part 2 Il s'agit de cours interactifs, couvrant l'intégralité de HTML5 et même beaucoup plus. L'inscription (gratuite) à HTML5 part 1 est obligatoire car on s'y réfèrera plusieurs fois. Sur la plateforme edX vous trouverez d'excellents MOOCs sur CSS, JavaScript etc. N'oubliez pas les cours sur les technos de référence du Web (HTML/CSS/JS bientôt sont sur la chaine W3Cx).

Séance 2 Introduction à JavaEE, rappels HTML/CSS/JavaScript

TP1 : écriture d'un gestionnaire de livres, avec deux implémentations, CDI, JDBC 

TP2: étude d'une correction du TP1 en Ajax, prise en main des EJBs et de JPA

Vous commencerez par étudier une correction en Ajax du TP1. Votre enseignant de TP vous donnera des infos complémentaires.

Correction du TP1 + aussi un client Ajax / Xhr2 avec des échanges en JSON

  • TP1M1Miage2015.zip, la partie Ajax se trouve pour le client dans ajaxClient.html, et côté serveur, dans les deux servlets BookListServlet.java et BookEditorServlet.java. Les appels Ajax utilisent les mêmes URLs mais ajoutent à la fin "?format=json", ce qui permet aux servlets de savoir si elles ont affaire à un appel Ajax ou pas...
     
  • Dans le cas d'un appel Ajax, les Servlets renvoient du JSON. Pour transformer des objets Java en JSON, on utilise la bibliothèque Jackson (voir bon tutorial ici).
    • Les deux jars ont été placés dans le répertoire lib du projet. C'est une bonne pratique si on veut distribuer un projet avec des .jars...
  • De la même manière dans le cas d'un ajout de livre en JSON, on envoie depuis ajaxClient.html, en JavaScript, un livre en JSON, et on le décode (transforme en objet Java instance de Book) avec Jackson. Vous verrez qu'on peut envoyer d'autres types d'encodage l'an prochain, notamment avec le format multipart, qui est aussi très pratique pour envoyer des formulaires en Ajax.

Passez donc un peu de temps à tester le projet, et à étudier ajaxClient.html et le code des de BookListServlet.java

Supports de cours JSP et JDBC

  • Les JSPs 2.0 (Java Server Pages, les composants "Vue" complémentaires des Servlets : JSPs.pptx

    • Comment "programmer des vues" dans des pages JSPs: support de cours en anglais sur le langage de templates JSTL (Java Standard Tag Library) et sur le langage EL (ou Expression language, à partir du transparent 31, JSTL à partir du 61), le reste n'est pas pertinent : jsp2.pdf.
  • JDBC : deux supports de cours très complets, en français, par Richard Grin : jdbc.pdf et jdbcavance.pdf. Le support utilisé en cours est un résumé de ce qui se trouve dans ces deux supports. On ne va plus faire de JDBC. Ces deux documents ont là comme référence au cas où.

Sujet du TP2: 

Séance 2 de cours: EJB/JPA + visite surprise

Support de cours :

TP3: terminer le TP2 + démarrer le nouveau TP

Vous commencerez par terminer le TP2. Il est à rendre pour la semaine prochaine. En binome. Il sera remis + démo pendant la prochaine séance de TP. Attention: si soupçon de triche -> zéro immédiat. 

Nouveau TP : Ajout de relations dans le TP3 / démarrage du mini projet 

Modifier la section

Le sujet cette fois-ci est assez simple:

1 - Ajoutez à chaque utilisateur une adresse sous la forme d'une relation 1-n (une personne a plusieurs adresses), vous commencerez par créer une entity Adresse.java qui contiendra comme propriétés :

  • No et nom de la rue,
  • Code postal
  • Ville
  • Pays

Puis vous rajouterez une collection d'adresse dans la classe Utilisateur.java (sous la forme d'une ArrayList, mais utilisez le wizard avec la petite lampe jaune pour cela).

Vous modifierez ensuite la méthode qui crée des données de test, et afficherez les adresses des personnes dans le tableau, soit directement (une liste dans une colonne du tableau), soit indirectement (affichage d'un lien qui renverra vers une autre page).

2 - Ajoutez aussi des numéros de téléphones

Idem