Séance 3 : requête POST

Introduction

Motivation

Jusqu’à maintenant, nous n’avons utilisé que des requêtes de consultation (GET et HEAD).

Il est parfois nécessaire de modifier les données du serveur. C’est notamment ce qui se passe lorsqu’on utilise un formulaire HTML (par exemple pour poster un billet de blog ou passer une commande).

Requête POST

Rappel : structure d’un formulaire

<form action="./comment/create" method="POST">
  <label>Nom : <input name="name"></label>
  <label>Adresse mél : <input name="email"></label>
  <label>Commentaire : <textarea name="comment"></textarea></label>
  <button>Laisser un commentaire</button>
</form>

Que se passe-t-il lorsqu’on clique sur le bouton ?

Requête POST de formulaire

Le navigateur envoie une requête POST à l’URL indiquée par l’attribut action. Le contenu de cette requête décrit les champs du formulaire, sous la forme suivante :

name=valeur1&email=valeur2&comment=valeur3

Ce format est identifié dans l’entête de message:

content-type: application/x-www-form-urlencoded

NB: les valeurs doivent être encodées selon un format particulier. En java, la classe java.net.URLEncoder offre cette fonctionnalité.

Autres formats de données

Le type de contenu application/x-www-form-urlencoded est bien adapté pour les formulaires HTML, mais n’est pas le seul possible.

Pour les services Web destinés à être utilisés par d’autres programmes, d’autres types (comme XML ou JSON) sont utilisés.

Note

D’ailleurs, même pour les formulaires HTML, lorsqu’on souhaite téléverser un fichier, on utilise un autre type de contenu : multipart/form-data.

Requête POST en Java

Exemple

URL url = new URL("http://httpbin.org/post");
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("POST");
conn.addRequestProperty("content-type", "application/x-www-form-urlencoded");
conn.setDoOutput(true);
OutputStream stream = conn.getOutputStream();
OutputStreamWriter writer = new OutputStreamWriter(stream);
writer.write("hello=world&bonjour=monde");
writer.close();
conn.connect();

Note

Cet exemple est un simple test. En situation réelle, il faut construire le contenu du message de manière robuste, notamment en utilisant java.net.URLEncoder.

Exemple JSON

URL url = new URL("http://httpbin.org/post");
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("POST");
conn.addRequestProperty("content-type", "application/json");
conn.setDoOutput(true);
OutputStream stream = conn.getOutputStream();
OutputStreamWriter writer = new OutputStreamWriter(stream);
writer.write("{ \"hello\": \"world\", \"bonjour\": \"monde\" }"); //
writer.close();
conn.connect();

Votre travail

Le contexte

Nous allons utiliser le Blog éphémère, un service de blog minimaliste dédié à ce cours.

Votre travail

Écrivez un programme qui

  • permette à l’utilisateur de saisir un titre et un contenu,

  • crée sur le blog éphémère un article avec ces informations,

  • affiche l’URL de l’article créé.

En commentaire de votre code, vous expliquerez le travail de rétro-ingénierie que vous aurez effectué pour pouvoir écrire ce programme (par exemple, en affichant le code source du formulaire de création, et en utilisant la console développeur de votre navigateur).