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 :

[linux] Socket operation on non socket


Sujet :

Réseau C

  1. #1
    Membre averti Avatar de let_me_in
    Inscrit en
    Mai 2005
    Messages
    441
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 441
    Points : 437
    Points
    437
    Par défaut [linux] Socket operation on non socket
    salut tout le monde, j'ai posté mon code dans le forum developpement linux, mais comme il y a eu aucune reponse depuis hier, je suis venu voir les gens d'ici.
    voici mon code :
    client:
    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
          #include <sys/socket.h>
          #include <sys/types.h>
          #include <netinet/in.h>
          #include <unistd.h>
          #include <stdlib.h>
          #include <errno.h>	
         #include <string.h>	
          #include <stdio.h>
     
          #define MAX_SEND 100
     
          int main()
     
          {
     
            int socket_connect, sockaddr_len;
     
            struct sockaddr_in sockaddr_connect,merde;
     
            char buffer[MAX_SEND];
     
            sockaddr_connect.sin_family = AF_INET;
     
            sockaddr_connect.sin_addr.s_addr = inet_addr("127.0.0.1");
     
            sockaddr_connect.sin_port = htons(6668);
     
    	sockaddr_connect.sin_zero[8]=0;
     
     
    	if(socket_connect = socket(AF_INET, SOCK_STREAM, 0) < 0)
     
            {
     
               printf("Socket creation errror !\n" );
     
               return EXIT_FAILURE;
     
            }
     
           printf("socket=%d\n",socket_connect);
     
            if(connect(socket_connect, (struct sockaddr*)&sockaddr_connect, sizeof(sockaddr_connect)) < 0)
     
            {
     
               printf("Socket connection error !\n" );
    	   perror("erreur");
     
               return EXIT_FAILURE;
     
            }
     
     
     
            while(1)
     
            {
     
               printf("send>" );
     
               scanf("%s", &buffer);
     
               write(socket_connect, buffer, MAX_SEND);
     
            }
     
     
     
            close(socket_connect);
     
            return 0;
     
          }
    serveur:
    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
        #include <sys/socket.h>
        #include <netinet/in.h>
        #include <unistd.h>
        #include <stdlib.h>
        #include <stdio.h>
        #include <time.h>
        #include <errno.h>	
     
        #define MAX_RECEPT 100
     
     
     
         int main(int argc, char* argv[])
     
          {
     
            if(argc < 2)
     
            {
               printf("Parameters error !\n" );
               return EXIT_FAILURE;
            }
            int socket_server, socket_client, server_len, client_len;
            struct sockaddr_in sockaddr_server, sockaddr_client;
            char buffer[MAX_RECEPT];
    	char buff[50];
            time_t date;
            FILE* f = fopen(argv[1], "a" );
            if((socket_server = socket(AF_INET, SOCK_STREAM, 0)) < 0)
              {
               printf("Socket creation error !\n" );
               return EXIT_FAILURE;
             }
            sockaddr_server.sin_family = AF_INET;
            sockaddr_server.sin_port = htons(6668);
            sockaddr_server.sin_addr.s_addr = INADDR_ANY;
            server_len = sizeof(sockaddr_server);
            client_len = sizeof(sockaddr_client);
            if(bind(socket_server, (struct sockaddr*)&sockaddr_server, server_len) < 0)
            {
     
               printf("Socket bind error !\n" );
    	   printf("%d\n",errno);
    	  perror("erreur :");
     
               return EXIT_FAILURE;
     
            }
     
            if(listen(socket_server, 10) < 0)
     
            {
     
               printf("Socket listen error !\n" );
     
               return EXIT_FAILURE;
     
            }
     
     
     
            printf("[~]Waiting connection... \n" );
     
            socket_client = accept(socket_server, (struct sockaddr*)&sockaddr_client, &client_len);
     
            printf("[~]Established connection !\n" );
     
     
     
            time(&date);
     
            fprintf(f, "[!]Established connection at %s\n", ctime(&date));
     
     
            while(1)
     
            {
     
               if(read(socket_client, &buffer, MAX_RECEPT) < 0)
     
               {
     
                  printf("Socket read error !" );
     
                  return EXIT_FAILURE;
     
               }  
     
     
     
               printf("From client : %s\n\n", buffer);  
     
               fprintf(f, "From client : %s\n", buffer);  
     
            }
     
     
     
            close(socket_client);
     
            printf("Saving in %s\n", argv[1]);
     
     
     
            return 0;
     
          }
    le serveur se lance bel et bien, mais le client me retourne cette erreur, et connect retourne 0 (j'ai lu quelque part que ceci n'est pas un probleme du fait que c'est >0).

    une idee la dessus?

    merci d'avance.
    qui dit Dieu n'existe pas dis que les programmes tournent sans processeur.

  2. #2
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(socket_connect = socket(AF_INET, SOCK_STREAM, 0) < 0)
    Quand je vois ce genre de choses, j'ai toujours des doutes sur la priorité.
    Et quand on a des doutes sur la priorité, on rajoute des parenthèses...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre expérimenté
    Avatar de muad'dib
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2003
    Messages
    1 011
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire Atlantique (Pays de la Loire)

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

    Informations forums :
    Inscription : Janvier 2003
    Messages : 1 011
    Points : 1 375
    Points
    1 375
    Par défaut
    Citation Envoyé par Médinoc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(socket_connect = socket(AF_INET, SOCK_STREAM, 0) < 0)
    Quand je vois ce genre de choses, j'ai toujours des doutes sur la priorité.
    Facile à vérifier
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #include <stdio.h>
     
    int main(void)
    {
    	int i;
     
    	printf("%d\n", i = -1 < 0);
    	printf("%d\n", i = -1 > 0);
     
    	return 0; 
    }
    affiche
    alex@megabomb:~$ ./prio
    1
    0
    Donc à priori pas de problème de priorité pour l'opérateur = suivi de comparaison < ou >.

    Cependant pour la clarté et pour le risque de priorité changeante selon les opérateurs, il vaut mieux mettre des parenthèses.

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Euh...
    Aucun problème pour le printf(), mais i ne faut pas la même chose selon la priorité (première ligne: i vaut-il -1 ou bien 1?)...

    Et dans le code passé, c'est i qui est important...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  5. #5
    Membre expérimenté
    Avatar de muad'dib
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2003
    Messages
    1 011
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire Atlantique (Pays de la Loire)

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

    Informations forums :
    Inscription : Janvier 2003
    Messages : 1 011
    Points : 1 375
    Points
    1 375
    Par défaut
    En modifiant le code ainsi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    	i = -1; 
    	printf("%d\n", i = -1 < 0);
    	printf("%d\n", i = -1 > 0);
    le résultat est le même

  6. #6
    Membre averti Avatar de let_me_in
    Inscrit en
    Mai 2005
    Messages
    441
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 441
    Points : 437
    Points
    437
    Par défaut
    Citation Envoyé par Médinoc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(socket_connect = socket(AF_INET, SOCK_STREAM, 0) < 0)
    Quand je vois ce genre de choses, j'ai toujours des doutes sur la priorité.
    Et quand on a des doutes sur la priorité, on rajoute des parenthèses...
    au fait c'est exactement ça, d'habitude je verifie toujours le truc des parentheses, mais la j'avais pris ce code du net donc je ne l'ai pas fait, maintenant le client marche tes bien, il y a un probleme de serveur maintenant qui me fait :
    mais je vais voir avec ça et je reviendrai apres.

    merci à tous.
    qui dit Dieu n'existe pas dis que les programmes tournent sans processeur.

  7. #7
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    ça viendrait pas de ça ton pbe :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
               scanf("%s", &buffer);
    Vu que le buffer est déjà alloué, il n'y a pas de & ..

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
               scanf("%s", buffer);
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  8. #8
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Citation Envoyé par muad'dib
    En modifiant le code ainsi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    	i = -1; 
    	printf("%d\n", i = -1 < 0);
    	printf("%d\n", i = -1 > 0);
    le résultat est le même
    Normal, tu m'as mal compris: Je voulais dire après la première ligne, i vaut-il -1 (i=-1) ou 1 (-1<0) ?

    Et d'après let_me_in, l'erreur était bien là: Au lieu d'avoir sa bonne valeur (qui dans l'exemple du printf, aurait du être -1, socket_connect (ou i) se retrouvait avec le résultat du test (1 ou 0).
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  9. #9
    Membre averti Avatar de let_me_in
    Inscrit en
    Mai 2005
    Messages
    441
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 441
    Points : 437
    Points
    437
    Par défaut
    Citation Envoyé par souviron34
    ça viendrait pas de ça ton pbe :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
               scanf("%s", &buffer);
    Vu que le buffer est déjà alloué, il n'y a pas de & ..

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
               scanf("%s", buffer);
    non non ça vient pas de la, d'ailleurs je l'ai viré cette scanf (je ne l'aime pas trop), j'ai utilisé fgets a la place.

    le probleme vient de la fonction fopen, qui me retourn null, pourtant le fichier existe bel et bien et est dans le meme repertoire que l'executable.
    quelqu'un a une idée ?

    merci a tous.
    qui dit Dieu n'existe pas dis que les programmes tournent sans processeur.

  10. #10
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    sans doute parce que tu as juste le nom du fichier et pas le chemin..

    Sous unixoide, mettre un nom sans chemin va chercher uniquement dans le répertoire d'OU est lancé le programme.

    Mais la manière la plus sûre est de construire le nom complet....
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  11. #11
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par let_me_in
    j'ai utilisé fgets a la place.

    le probleme vient de la fonction fopen, qui me retourn null, pourtant le fichier existe bel et bien et est dans le meme repertoire que l'executable.
    quelqu'un a une idée ?
    Est-tu bien conscient que fgets() prend aussi le \n et qu'il convient de l'éliminer proprement ?
    Pas de Wi-Fi à la maison : CPL

  12. #12
    Membre averti Avatar de let_me_in
    Inscrit en
    Mai 2005
    Messages
    441
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 441
    Points : 437
    Points
    437
    Par défaut
    le problème c'est que le fichier est dans le meme repertoire que l'executable, mais j'ai quand meme essayé de lui passer le chemin depuis '/' mais rien a faire ça retourne toujours NULL.

    Citation Envoyé par Emmanuel Delahaye
    Est-tu bien conscient que fgets() prend aussi le \n et qu'il convient de l'éliminer proprement ?
    oops, j'avais oublié ça, je vais le faire !
    qui dit Dieu n'existe pas dis que les programmes tournent sans processeur.

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

Discussions similaires

  1. socket en mode non-blocking
    Par ikuzar dans le forum Réseau
    Réponses: 3
    Dernier message: 16/02/2011, 12h12
  2. Passer une socket en mode non bloquant
    Par ProgVal dans le forum Langage
    Réponses: 2
    Dernier message: 24/12/2009, 21h15
  3. Socket udp, recvfrom non bloquant
    Par yellowboy dans le forum C++
    Réponses: 0
    Dernier message: 26/05/2008, 22h10
  4. [socket] socket operation on non socket
    Par let_me_in dans le forum Linux
    Réponses: 1
    Dernier message: 19/06/2007, 18h59
  5. [Linux] Probleme de fermeture de Sockets
    Par diefo dans le forum Réseau
    Réponses: 6
    Dernier message: 30/12/2003, 13h10

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