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

Réseau C Discussion :

TCP, libpcap et données encapsulées


Sujet :

Réseau C

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 16
    Points : 7
    Points
    7
    Par défaut TCP, libpcap et données encapsulées
    Bonjour à tous.

    Je suis débutant en programmation C. Le projet que je tente de réaliser actuellement nécessite un sniffer réseau. J'utilise donc libpcap pour récupérer les paquets, mais j'ai un léger probleme lors de la reception d'un paquet TCP/IP.

    En fait, je souhaiterai récupérer les données encapsulées dans le paquet. Cependant, je ne comprends pas comment faire car il semblerait que TCP puisse ajouter des options facultatives à la fin de l'entête. Or, sans connaître la taille de cette dernière, comment puis-je accéder aux données qu'elle encapsule ?

    Voici un bout de code (naïvement, j'utilise une arithmétique de pointeurs.) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    void on_tcp_pkt(struct ethhdr* eth, struct iphdr* ip, const struct pcap_pkthdr* pkthdr, const u_char* packet){
        /*Routine chargée d'analyser le paquet TCP*/
        struct tcp_bsd_hdr* tcp = (struct tcp_bsd_hdr*)(packet + 14 + 4*(ip->ihl));
        int siz = pkthdr->len - sizeof(struct ethhdr) - 4*(ip->ihl);
        if (siz > sizeof(struct tcp_bsd_hdr)){
            printf("Le paquet contient une raw de taille : %d : %s \n",siz - sizeof(struct tcp_bsd_hdr), tcp + sizeof(struct tcp_bsd_hdr));
        }
        else
            printf("Le paquet ne contient pas de raw\n");
        return;
    }
    Ma structure tcp_bsd_hdr :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    struct tcp_bsd_hdr {
        u_short         tcp_port_src;     /* port source */
        u_short         tcp_port_dst;      /* port de destination */
        u_long          tcp_seqnum;     /* numero de sequence */
        u_long          tcp_aqunum;     /* numero d'aquittement */
        u_char          tcp_res;     /* decalage, reserve, hlen, ecn ? */
        u_char          tcp_flags;   /* Flags : URG, ACK, PSH, RST, SYN, FIN */
        u_short         tcp_win;     /* taille fenetre demandee */
        u_short         tcp_crc;     /* Checksum */
        u_short         tcp_purg;     /* pointeur donnees urgentes */
    };
    Merci d'avance pour le temps que vous m'accorderez.

    Cordialement, Sat.

  2. #2
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Points : 50 367
    Points
    50 367
    Par défaut
    Le header TCP que tu utilises (tcp_bsd_hdr) n'est pas tout à fait correct. Regarde dans la RFC 793, tu as un header TCP correct.

    Effectivement, TCP peut ajouter des options dans son header. La taille du header TCP est indiquée par le champs "Data Offset" du header qui contient le nombre de mots de 32 bits utilisés par le harder. Avec cette valeur et la taille de la trame TCP (récupérée dans le header IP), tu peux alors calculer le début de la trame de données.
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 16
    Points : 7
    Points
    7
    Par défaut
    Merci beaucoup, tout marche à présent.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. TCP : réception de données
    Par contremaitre dans le forum Réseau
    Réponses: 10
    Dernier message: 19/06/2008, 11h11
  2. Réponses: 11
    Dernier message: 08/03/2007, 14h29
  3. Réponses: 6
    Dernier message: 11/02/2006, 12h07
  4. [xml] Encapsulation de données binaires
    Par yanoche dans le forum XML/XSL et SOAP
    Réponses: 4
    Dernier message: 30/11/2005, 14h32
  5. Delphi Connexion à une base de donnée distante par TCP/IP
    Par viecel dans le forum Bases de données
    Réponses: 1
    Dernier message: 12/01/2005, 19h19

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