begin process at 2012 05 28 19:11:58
  Trouver un code source :
 
dans
 
Accueil > Forum > 

C++ & C++ .NET

 > 

Windows

 > 

Réseau & Internet

 > 

comportement recv de Winsock etrange


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

comportement recv de Winsock etrange

lundi 28 août 2006 à 15:46:13 | comportement recv de Winsock etrange

thejojo1

Salut jespere quun spécialiste de winsock va pouvoir maider! Voila je programme un serveur ftp et tout marche... en reseau local! Sur internet c'est une autre affaire. En fait je rencontre une erreur lors de l'upload d'un fichier. Il semble que certains paquets soient envoyés 2 fois. Voici le code qui pose problème:

LRESULT CALLBACK ProcessMessage(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
 switch (uMsg)
 {
 
  case 1025: //WINSOCK message

   switch (lParam)
   {
    case FD_READ:

    if (wParam==FTPDATASOCK || wParam==REMOTEFTPCLIENTDATASOCK)
     {
      char *buffer=(char *) malloc(8192*sizeof(char));
      int recu=1;
      while (recu>0)
      { 
       ZeroMemory(buffer,8192);
       recu=recv(wParam,buffer,8192,0);
       if (HFTPDATAFILE!=NULL)
        fwrite(buffer,sizeof(char),recu,HFTPDATAFILE);
       Sleep(1000);
      }
      return 0;
     } 
   }
}

J'utilise des sockets non bloquantes (WSAAsyncSelect) et ceci est la procédure pour recopier un fichier transféré. En local je mets Sleep(50) pour maximiser la vitesse de transfert (200ko/s), mais si je mets cette valeur pour une utilisation sur internet alors les fichiers transférés auront une taille plus grosse qu'à l'origine. Et si je laisse Sleep(1000) alors le temps de téléchargement devient incroyablement long! Pour info, HFTPDATAFILE=fopen(filename,"wb");

Jattends vos conseils! Merci

lundi 28 août 2006 à 18:40:53 | Re : comportement recv de Winsock etrange

thejojo1

Bon finalement jai trouvé. Comme quoi avec un peu d'acharnement on arrive à nos fins. Toutefois je ne vois pas pourquoi ca marche donc un peu d'éclaircissement serait le bienvenu;

      if (wParam==FTPDATASOCK)// || wParam==REMOTEFTPCLIENTDATASOCK)
     {
      char *buffer=(char *) malloc(8192*sizeof(char)); 
      int recu=1;
      MSG msg;
      while (recu>0)
      { 
       ZeroMemory(buffer,8192);
       recu=recv(wParam,buffer,8192,0);
       if ((HFTPDATAFILE!=NULL)&(recu>0))  //au cas ou les msg ont du retard la connexion est ptete deja fermée
        fwrite(buffer,sizeof(char),recu,HFTPDATAFILE);
       
       if(PeekMessage(&msg,NULL,0,0,PM_REMOVE))
       {
         TranslateMessage(&msg);
         DispatchMessage(&msg);
       }

      }
      return 0;
     } 

Visiblement rajouté &(recu>0) convient. En fait fwrite devait écrire dans le fichier meme avec recu=0. C'est ca que je ne comprends pas bien. La gestion des messages apparait anecdotique mais au moins on ne bloque pas l'application.
Avec un peu de chance j'aurai aidé quelqu'un avec mon probleme!
lundi 28 août 2006 à 22:56:23 | Re : comportement recv de Winsock etrange

aardman

Membre Club
Salut,
Il y a pas mal de problemes dans ton code.
- Déja il manque le free(buffer), ce qui crée un gros mémory leak (8 Ko a chaque fd_read, pour un client ftp c'est énorme).
- Ensuite le PeekMessage() que tu as mis dans le deuxieme post n'est pas utile, il va enlever un message de la pile 'aléatoirement'... Dans le post précedent tu avais mis un Sleep(1000) mais tu te plaignais que la vitesse de transfert etait lente: a quoi sert - il ?
- Enfin, je ne vois aucun traitement d'erreur dans ton code, ce qui me semble indispensable pour un client ftp, car la fin du transfert sur une connexion de transfert est marquée par la déconnection du socket.  Il faut donc traiter systematiquement les erreurs qui se trouvent dans HIWORD(lParam)  lorsque tu recois FD_READ, ainsi que les erreurs que pourraient retourner recv(). Il peut aussi arriver que lorsqu'on recoit un FD_CLOSE, le buffer de reception du socket ne soit pas vide, auquel cas on peut verifier s'il reste encore des données a lire avec ioctlsocket(), puis faire un ou plusieurs recv() au besoin.




Cette discussion est classée dans : buffer, winsock, wparam, char, recu


Répondre à ce message

Sujets en rapport avec ce message

Question sur les pointeurs [ par Darkneon ] Voici un programme tiree de "Simple C++"#include #include class Court{private: //attributes char * Aide Sockets Winsock [ par VoLc0m ] voila mon pb :en C bien sur :) je dois, par socket, envoyer ca a une address (server counter strike) :The packet should start with 4 consecutive bytes taille chaine de char [ par langedechu ] Salut , voila mon prob (je sais plus comment faire) :j'ai une variable : const char *buffer; et j aimerais savoir le nombre de caractere stocker dans mon prog plante [ par lcampeur ] Voilà, j'ai un programme qui consiste a envoyer des fichiers quelconques sur des postes référencés précedemment. Je dois pouvoir envoyé plusieurs fich mon prog plante :-( [ par lcampeur ] Voilà, j'ai un programme qui consiste a envoyer des fichiers quelconques sur des postes référencés précedemment. Je dois pouvoir envoyé plusieurs fich Fuite de mémoire pas bien mechante mais suante [ par Trollien ] Bonjour,j'approfondi mais diverses connaissances en c++ et je suis tombé sur un phénomène bien connu et plutôt génant dans une application temps réel. SVP besoin d'aide [ par seito ] [size=5] seito [/size]j'ai déveloper une apploication pour transferer des fichiersla reception est parfaite pourtant à l'envoie ça me cause des tas de Pb vector de vector de char ! [ par nicolas66 ] Ben g un pti pb avec ce prog en Cpp, à la compile ca passe mé à l'execution ca plante !! si vous savé pk merci d'avance !(c censé initialisé un buffer char* -> string [ par oRTEEZ ] Voila tout est dans le sujet.En fait j'ai un nom de fichier dans un buffer et j'aimerai ajouter des caractere au nom.ex: *buffer = "voila.jpg"apres tr recv() et du brol [ par epoc ] hum... encore moi!g un petit prob avec la fonction recv() ou send(), je c pas trop.dans mon client j'ai ça :char *buffer = new char[1024];buffer="NEW


Nos sponsors


Sondage...

Comparez les prix

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,437 sec (4)

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