From 3feef2d05576d1fa1be0bf78a91b9c77f517ff73 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sylvain=20Desv=C3=A9?= Date: Tue, 12 Oct 2010 21:35:37 +0200 Subject: [PATCH] Updated French README with request object documentation. Signed-off-by: Konstantin Haase --- README.fr.rdoc | 47 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+) diff --git a/README.fr.rdoc b/README.fr.rdoc index 8c3e6ff0..12d482ae 100644 --- a/README.fr.rdoc +++ b/README.fr.rdoc @@ -609,6 +609,53 @@ On sort donc immédiatement de ce gestionnaire et on continue à chercher, dans les masques suivants, le prochain qui correspond à la requête. Si aucun des masques suivants ne correspond, un code 404 est retourné. +== Accéder à l'objet requête + +L'objet correspondant à la requête envoyée peut être récupéré dans le contexte de la requête (filtres, routes, gestionnaires d'erreur) au moyen de la méthode `request`: + + # application tournant à l'adresse http://exemple.com/exemple + get '/foo' do + request.body # corps de la requête envoyée par le client (voir ci-dessous) + request.scheme # "http" + request.script_name # "/exemple" + request.path_info # "/foo" + request.port # 80 + request.request_method # "GET" + request.query_string # "" + request.content_length # taille de request.body + request.media_type # type de média pour request.body + request.host # "exemple.com" + request.get? # true (méthodes similaires pour les autres verbes HTTP) + request.form_data? # false + request["UN_ENTETE"] # valeur de l'entête UN_ENTETE + request.referer # référant du client ou '/' + request.user_agent # user agent (utilisé par la condition :agent) + request.cookies # tableau contenant les cookies du navigateur + request.xhr? # requête AJAX ? + request.url # "http://exemple.com/exemple/foo" + request.path # "/exemple/foo" + request.ip # adresse IP du client + request.secure? # false + request.env # tableau brut de l'environnement fourni par Rack + end + +Certaines options, telles que script_name ou path_info peuvent +également être modifiées: + + before { request.path_info = "/" } + + get "/" do + "toutes les requêtes arrivent ici" + end + +request.body est un objet IO ou StringIO: + + post "/api" do + request.body.rewind # au cas où il a déjà été lu + donnees = JSON.parse request.body.read + "Bonjour #{donnees['nom']}!" + end + == Configuration Lancé une seule fois au démarrage de tous les environnements: