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 :

Adresse mémoire d'une variable d'environnement


Sujet :

Python

  1. #1
    Membre à l'essai
    Homme Profil pro
    Secret
    Inscrit en
    Juin 2015
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Secret

    Informations forums :
    Inscription : Juin 2015
    Messages : 12
    Points : 14
    Points
    14
    Par défaut Adresse mémoire d'une variable d'environnement
    Bonjour à tous,

    Ces derniers temps je me suis interessé au BOF et je suis occuper de faire de nombreux challenges. Dans le cadre de l'exploitation d'un bof, nous pouvons mettre un shellcode dans une variable environnement. Nous devons par la suite trouver l'adresse mémoire de cette variable environnement. Pour ce faire, j'ai trouvé un code en c que je vous donne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
     
    int main(int argc, char *argv[]) {
        char *ptr;
     
        if(argc < 3) {
            printf("Usage: %s <environment variable> <target name program>\n", arg$
            exit(EXIT_FAILURE);
        }
     
        ptr = getenv(argv[1]); /* get env var location */
        ptr += (strlen(argv[0]) - strlen(argv[2]))*2; /* adjust for program name */
     
        printf("%s will be at %p\n", argv[1], ptr);
     
        return EXIT_SUCCESS;
    }
    Etant pas trop friands de C et je me suis mis en tête de coder le même programme en python. J'ai donc transposer le code plus haut en python voici mon code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    import os
    import sys
     
    env = sys.argv[1]
    bin = sys.argv[2]
     
    if sys.argv < 3:
        print("Usage python3 getenv.py <VARIABLE> <BINAIRE>")
     
    else:
        ptr = id(os.environ[env])
        ptr+=(len(sys.argv[0])-len(sys.argv[2]))*2
        print("L'adresse de "+env+" est à "+hex(ptr))

    Néanmoins, lorsque je compare les deux adresses (celle du prog C et celle de python) elle ne sont pas identique et celle du C est bien la bonne. J'aimerais savoir si, mon code est mauvais où si le décalage provient de l'interpréteur python en lui même ?
    Merci de vos réponses.

    Cordialement

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Salut,

    Citation Envoyé par NeOaCk Voir le message
    J'aimerais savoir si, mon code est mauvais où si le décalage provient de l'interpréteur python en lui même ?
    Avec Python, les pointeurs n'existent pas.
    De plus lorsque vous écrivez ptr = id(os.environ[env]) vous récupérez sur CPython l'adresse de l'objet chaîne de caractères retourné par os.environ (qui n'est pas l'adresse de la chaîne de caractères).
    Pour faire çà, il faut peut être utiliser le "getenv" de la libc via ctypes.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre à l'essai
    Homme Profil pro
    Secret
    Inscrit en
    Juin 2015
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Secret

    Informations forums :
    Inscription : Juin 2015
    Messages : 12
    Points : 14
    Points
    14
    Par défaut
    Merci pour ta réponse, je me doutais bien que cela venait de la non-existence des pointeurs mais comme cela est obscure pour moi je vais chercher vers ctype.

    Merci encore

Discussions similaires

  1. Voir l'adresse mémoire d'une variable dans Eclipse
    Par foreman dans le forum Eclipse Java
    Réponses: 3
    Dernier message: 13/03/2013, 00h12
  2. [C#] Récupération d'une variable d'environnement
    Par jamy79 dans le forum ASP.NET
    Réponses: 1
    Dernier message: 17/08/2005, 14h03
  3. NASM Tester une variable d'environnement à la "compilat
    Par Pierre Maurette dans le forum Assembleur
    Réponses: 1
    Dernier message: 10/06/2005, 13h27
  4. [BES] Création d'une variable d'environnement
    Par NGI80 dans le forum Autres
    Réponses: 2
    Dernier message: 17/10/2002, 07h31

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