begin process at 2012 05 30 17:27:28
  Trouver un code source :
 
dans
 
Accueil > Forum > 

C++ & C++ .NET

 > 

Windows

 > 

Réseau & Internet

 > 

socket UDP - récupérer réponse


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

socket UDP - récupérer réponse

dimanche 24 février 2008 à 13:00:39 | socket UDP - récupérer réponse

_Xav_

Hello tout le monde, voici mon problème:

J'ai écris une class dns avec laquelle j'envoie des paquets (en udp) et j'aimerais recevoir les réponses faites par mon serveur dns.

Le problème est que je ne sais pas comment récupérer le port d'émission afin de mettre ce port en écoute pour récupérer la réponse.

Je pense que cela doit être tout bête donc si qqn aurait la solution ça m'aiderait beaucoup.

Merci

PS: sockets windows.
dimanche 24 février 2008 à 13:37:20 | Re : socket UDP - récupérer réponse

aardman

Membre Club
Salut,
Logiquement la reponse devrait revenir sur le port qui a envoyé la requete, donc il n'y a pas de deuxieme socket a binder pour recevoir les requetes, tout se passe sur le premier.

dimanche 24 février 2008 à 13:51:58 | Re : socket UDP - récupérer réponse

_Xav_

Donc j'utilise le même descripteur (SOCKADDR_IN) dans mon appel à recvfrom...?

En clair j'ai:
                        sendto(sock, msg.c_str(), msg.size(), 0, (SOCKADDR*)&sin, sizeof(sin))
et ensuite
                        recvfrom(sock, buffer, sizeof(buffer), 0, (SOCKADDR*)&sin, &sinsize)


sock = ma socket
msg = string contenant mon message à envoyer
buffer = bufer de réception
sin = descripteurde type SOCKADDR_IN de ma socket
dimanche 24 février 2008 à 15:50:11 | Re : socket UDP - récupérer réponse

aardman

Membre Club
Salut,
C'est une mauvaise idée d'utiliser la meme structure pour ces deux appels, car ils ne representent pas la meme chose:
- la structure sin que tu passes a sendto est un parametre d'entrée qui specifie l'adresse de destination de ton paquet udp,
- la structure sin que tu passes a recvfrom est un parametre de sortie (optionnel) qui specifie l'origine du paquet, autrement dit l'adresse qu'elle contient avant l'appel a recvfrom n'a aucune importance, c'est l'adresse une fois que la fonction a retourné qui est importante.

Il faut donc utiliser deux structures differentes, avec des noms un peu plus parlant que 'sin'.
D'autant plus que les paquets que tu recois ne proviennent pas forcement de ton serveur dns, donc si tu écrases l'adresse de ton serveur dns avec l'adresse d'origine tu paquet, ca sera plus compliqué pour comparer les deux adresses.

Aussi, si tu dialogues uniquement avec un serveur dns, tu peux aussi regarder ce que fait connect() sur msdn: ça permet de specifier une adresse distante pour ton socket udp, et ça permet d'ignorer silencieusement tout les paquets qui ne proviennent pas de cette adresse, ce qui est pratique.






mardi 26 février 2008 à 14:35:41 | Re : socket UDP - récupérer réponse

_Xav_

Salut,

j'ai finalement utilisé connect et qu'un descripteur (SOCKADDR_IN) contenant les infos sur la destination.

J'aurais encore une question stp:
    - Comment rendre recv() non-bloquant sans utiliser de threads. Il existe select je crois? As-tu un exemple sous la main? Sinon     je googlerais...

Merci
mardi 26 février 2008 à 22:35:37 | Re : socket UDP - récupérer réponse

aardman

Membre Club
Réponse acceptée !
Salut,
En plus de select, il existe aussi WSAEventSelect et WSAAsyncSelect pour gerer les sockets non bloquants, WSAAsyncSelect est particulierement pratique si tu as une interface graphique (avec une boucle de message).
Voici un ebook de reference qui contient la documentation et les exemples pour utiliser select et les autres modeles cités ci dessus:
http://betouchi.free.fr/doc_et_ebook/prog_reseau/network2.chm pour l'ebook,
http://betouchi.free.fr/doc_et_ebook/prog_reseau/exemples-network2.zip pour les exemples.

mercredi 27 février 2008 à 09:38:22 | Re : socket UDP - récupérer réponse

_Xav_

merci aardman, je crois que maintenant j'ai de quoi faire...



Cette discussion est classée dans : réponse, problème, récupérer, socket, udp


Répondre à ce message

Sujets en rapport avec ce message

Problème de socket UDP sous linux [ par RaygKross ] Salut à tousMon problème est je dois créer un programme manager snmpLes port de SNMP sont 161 et 162J'initialise ma structure de type sockaddr_in avec Problème UDP [ par ToToL ] BonjoursJe me suis attaquer il y a peut de temps au socket UDP ( aparament plus rapide que le tcp ) et j'ai un petit souci : je n'arrive pas ds le mem Décryptage de packets UDP [ par Ezekiel69 ] Bonjour a tous,Je travaille actuellement sur un programme qui me permettrait de récupérer des info transitions entre le serveur et le client d'un jeu. Problème de type de donnée avec ADO [ par mackleod ] Salut,Voila mon problème : J'utilise ADO dans une application afin de récupérer des données présents sur base Oracle.La difficulté que je rencontre vi Problème lors de la fermeture de sockets [ par malik7934 ] Hello,J'ai dans mon programme un socket qui est ouvert et j'envoie d'un client vers un serveur (et vice versa) des infos qui sont traîtées à chaque fo Récupérer des entrées clavier hors d'une fenêtre Win21 [ par Taranael ] Salut ! Bon j'ai un problème pour un p'tit programme idiot que j'ai fait, c'est un piano tout con en C qui joue de la musique avec votre tourelle quan Lire une reponse UDP dans une socket [ par topl ] bonjour,Je crée un petit prog qui envoi une requete à un serveur dns afin de resoudre le nom tel que "www.yahoo.com".Seulement lorsque je fais un rec récupérer le handle d'un socket [ par Nebula ] Bonjour à tous !J'aimerais savoir s'il y a un moyen quelconque de récupérer le handle global d'un socket, de manière à pouvoir l'utiliser dans une app Socket TCP/UDP [ par hobbes ] Bonjour,j ai cru comprendre qu il existe 2 types de sockets (TCP et UDP) pouvant permettre l echange de donnees entre 2 applications sur le reseau.Pou Erreur 10049 sur socket UDP [ par Ezekiel69 ] Salut tous le monde...Me voici depuis plusieurs jour confronté un a problème étrange.Je veux envoyer un message par l'intermédiaire d'un packet UDP su


Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,780 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales