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

MFC Discussion :

[MFC] Problème Socket + Connexion SQL


Sujet :

MFC

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 5
    Points : 1
    Points
    1
    Par défaut [MFC] Problème Socket + Connexion SQL
    Bonjour à tous,

    Voilà je développe sur VC++ 6.0 en MFC.
    J'utilise l'API mysql++.

    Mon programme à l'appui sur un bouton utilise une méthode qui crée une Socket Serveur qui se met à l'écoute d'un poste distant (appelé Superviseur). Lorsque le message est reçu la méthode envoie comme résultat une chaîne DataPacket qui est utilisé dans une autre méthode pour récupérer un "cycle" (un ensemble de valeurs) grâce à des requêtes SQL :

    SocketServeur :
    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
     
    CString C_Serveur::ServerConnection(int iListenPort)
    {
    	//fonction serveur
    	SocketObject	ServerSocketObject ;
    	SocketObject	ClientSocketObject ;
    	char			DataPacket[128] ;			// Paquet de données à recevoir
    	int				iBytesReceived ;		    // # d'octets reçus
     
    	// tentative de lancement du serveur
    	if (ServerSocketObject.Bind(iListenPort))
    	{
     
    		AfxMessageBox("Tentative d'écoute sur le port");
     
    	   	// Ecoute sur le port
    		ServerSocketObject.Listen();
     
    		// Acceptation de connexion
    		ServerSocketObject.Accept(ClientSocketObject);
     
    		// Reception de données
    		iBytesReceived = ClientSocketObject.Recv(DataPacket, 128, 0);
     
    //		char* nom_operateur ;
    //		strcpy (nom_operateur, nom_BDD) ;
     
    //		iBytesReceived = ClientSocketObject.Send(nom_operateur, 128, 0);
    	}
       	else 
    	{
    		AfxMessageBox("<Serveur> : Connexion impossible") ;
    	}
     
    	CString reponse;
    	ServerSocketObject.Disconnect();
    	ClientSocketObject.Disconnect();
     
    	reponse.Format("%s", DataPacket);
     
    	return reponse ;
    }
    la fonction recup_cycle utilise seulement des :
    - mysql_real_connect
    - mysql_close
    - mysql_query

    Mon problème :
    Les deux méthodes ne marchent pas entre elles :
    Lorsque j'utilise la méthode recup_cycle (MySQL) seul, elle marche niquel
    Lorsque j'utilise la Socket Server seul, elle marche niquel

    Les deux foirent, pas à la compilation mais à l'exécution, lorsque j'ai crée ma Socket et que je fais appelle aux fonctions sql, il me dis que je n'ai pas de BDD :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    L'instruction à "0x10006db5" emploie l'adresse mémoire "0x00000014". La mémoire ne peut pas être "read".
    Et quand je lance le Debugger il me met
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Unhandled exception in TabCtrl.exe (LIBMYSQL.DLL) : 0xC0000005: Access Violation.
    Voilà si vous avez une idée 8)

  2. #2
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 5
    Points : 1
    Points
    1
    Par défaut
    Je suis désolé d'insister aussi rapidement mais je dois régler ce problème assez vite car je n'avance plus dans mon projet...
    Comme ça n'a pas l'air dinteresser grand monde je peux peut être ajouter des précisions ?

  3. #3
    Rédacteur
    Avatar de nico-pyright(c)
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    6 414
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 6 414
    Points : 16 075
    Points
    16 075
    Par défaut
    en debbuggant, quel est la ligne qui provoque l'access violation ?

  4. #4
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 5
    Points : 1
    Points
    1
    Par défaut
    Merci nico de ton aide, alors l'erreur se crée à la ligne :

    De ma méthode :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CString C_Serveur::ServerConnection(int iListenPort)

  5. #5
    Rédacteur
    Avatar de nico-pyright(c)
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    6 414
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 6 414
    Points : 16 075
    Points
    16 075
    Par défaut
    es-tu bien sur que DataPacket possède un \0 terminateur ?

  6. #6
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 5
    Points : 1
    Points
    1
    Par défaut
    Bonne question, mon cher collègue qui m'envoie la chaîne à lire (en PHP)
    concatène sa chaîne avec un '\0' donc pour moi oui DataPacket est bien terminé par un zéro terminal.

  7. #7
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 5
    Points : 1
    Points
    1
    Par défaut
    Pas d'autres idées ?
    Question certainement idiote : est ce qu'il pourrais exister un "conflit" entre ma connexion Client / Serveur via la Socket et ma connexion MySQL ?

    Car le problème de BDD non trouvé vient depuis la création et l'utilisation des Sockets dans mon projet...

Discussions similaires

  1. Problème de connexion SQL Server 2005
    Par c22c07 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 23/06/2006, 16h32
  2. [SQL-Server] Problème de connexion à SQL SERVER
    Par tit_oune dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 27/04/2006, 08h14
  3. [MySQL] Problème de connexion SQL depuis 1 script distant chez Free
    Par metalfire77 dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 23/04/2006, 07h26
  4. Problème de connexion SQL Server 2005
    Par kanko dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 13/02/2006, 17h14
  5. [VB.NET] Problème de connexion à SQL Server
    Par Nesmontou dans le forum ASP.NET
    Réponses: 8
    Dernier message: 29/07/2005, 10h12

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