IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Python Discussion :

Récupérer la valeur du Location d'un header


Sujet :

Python

  1. #1
    Membre averti
    Profil pro
    Développeur Full Stack
    Inscrit en
    Janvier 2007
    Messages
    30
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Full Stack

    Informations forums :
    Inscription : Janvier 2007
    Messages : 30
    Par défaut Récupérer la valeur du Location d'un header
    Bonjour,

    Dans le cas où je veux récupérer une page, et que celle-ci est une redirection vers une autre page :
    La librairie urllib2 me renvoie directement les informations de l'autre page (la page redirigée).
    Mais j'aimerais connaitre les headers (et notamment la valeur du champ 'Location' et du code de redirection) de la page d'origine, celle que j'ai appelé.

    Ainsi, si j'appelle la page 'developpez.net' avec Chrome, je suis renvoyé sur : http://www.developpez.net/forums/
    et donc urllib2 me renvoie les infos de cette page.

    J'aimerais les headers de 'http://developpez.net', qui devraient me renvoyer vers http://www.developpez.net/ et qui, lui, devrait me renvoyer vers http://www.developpez.net/forums/

    Au passage, je signale une erreur : http://developpez.net sur Firefox créé une boucle et une erreur de redirection.

    Merci d'avance,


    Version :: Python 2.7.10

  2. #2
    Membre averti
    Profil pro
    Développeur Full Stack
    Inscrit en
    Janvier 2007
    Messages
    30
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Full Stack

    Informations forums :
    Inscription : Janvier 2007
    Messages : 30
    Par défaut
    Je m'était égaré avec une mauvaise librairie (urllib2) qui semble t-il ne permet pas de le faire.

    Il semblerait que ca marche avec httplib :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    import httplib
     
    try:
        h = httplib.HTTPConnection("example.com")
        h.connect()
    except Exception as ex:
        print "Could not connect to page."
     
    h.request("HEAD", "/")  # Could also use "HEAD" instead of "GET".
    response = h.getresponse()

    A priori, HEAD sert à ne récupérer que les headers, là où GET sert à récupérer toute une page.


    Merci !

  3. #3
    Membre expérimenté Avatar de cervo
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2012
    Messages
    220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2012
    Messages : 220
    Par défaut

    Je pense que tu devrais simplement utiliser la methodde response.info() de urllib
    Depuis la DOC:
    urllib2.urlopen(url[, data][, timeout])
    ....
    This function returns a file-like object with two additional methods:
    geturl() — return the URL of the resource retrieved, commonly used to determine if a redirect was followed
    info() — return the meta-information of the page, such as headers, in the form of an httplib.HTTPMessage instance (see Quick Reference to HTTP Headers)

  4. #4
    Membre averti
    Profil pro
    Développeur Full Stack
    Inscrit en
    Janvier 2007
    Messages
    30
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Full Stack

    Informations forums :
    Inscription : Janvier 2007
    Messages : 30
    Par défaut
    Le problème de urllib2.urlopen sur lequel je me suis focalisé dans un premier temps, c'est qu'elle ne retourne que les infos de la dernière page.
    Un exemple :

    La page A renvoie vers la page B qui renvoie vers la page C.
    Ce qui m'intéresse, moi, ce sont les informations de la page que l'on appelle, soit la page A.
    urllib2 me renverra les informations de la page C, sans m'informer qu'il y a une page B.
    Alors effectivement, je verrais bien que l'url de la page C est différente de celle de la page B, mais c'est tout.

    Avec httplib, j'ai bien l'information concernant la page B, et le type de redirection (status 301, 302), ce qui est l'objet même de mon dev.

Discussions similaires

  1. DBGrid récupérer les valeurs de l'enregistrement courant
    Par bob_sapp dans le forum Bases de données
    Réponses: 5
    Dernier message: 06/09/2014, 07h56
  2. récupérer la valeur du 2ème champ dans un DBLookUpListBox
    Par jakouz dans le forum Bases de données
    Réponses: 3
    Dernier message: 20/07/2004, 16h45
  3. Réponses: 2
    Dernier message: 03/06/2004, 08h32
  4. [Couleur] Récupérer les valeurs R,V,B et L,U,V ?
    Par M4v3rick dans le forum C++Builder
    Réponses: 4
    Dernier message: 25/01/2004, 03h28
  5. récupérer la valeur de sortie d'un thread
    Par jakouz dans le forum Langage
    Réponses: 3
    Dernier message: 31/07/2002, 11h28

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo