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

PHP & Base de données Discussion :

Connexion impossible sur le serveur MySQL [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut Connexion impossible sur le serveur MySQL
    Bonsoir,

    je tente une connexion à la bdd MySQL en mysqli procédural ; ça échoue et je ne comprends pas :

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    echo "tentative de connexion<br/>";
    $dbase="su_dev_eis";
    $link=mysqli_connect('localhost','root','root',$dbase);
    if (mysqli_connect_errno()) {
    	printf("test Connexion impossible sur le serveur MySQL : %s\n", mysqli_connect_error());
    	exit();}

    Les paramètres login="root" et pwd="root" sont ceux que j'utilise pour me connecter à phpMyAdmin (wampserver est installé sur un serveur et non sur mon PC). Le messsage d'erreur s'affiche bien mais pas le echo "tentative de connexion<br/>";
    Connexion impossible sur le serveur MySQL : Access denied for user 'root'@'localhost' (using password: NO)

  2. #2
    Membre habitué
    Avatar de romuluslepunk
    Homme Profil pro
    Juste passioné
    Inscrit en
    Avril 2005
    Messages
    174
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Belgique

    Informations professionnelles :
    Activité : Juste passioné

    Informations forums :
    Inscription : Avril 2005
    Messages : 174
    Points : 154
    Points
    154
    Par défaut
    Bonjour,

    Ton serveur mysql est-il paramétré pour recevoir une connexion distante (et le firewall) ?
    Pourquoi utiliser localhost si le serveur est à distance ?

    Si le localhost n'est là que pour nous montrer ton code sans danger et que le firewall du serveur est bien configuré, vérifie que l'utilisateur accepte une connexion à distance (root n'est pas configuré pour de base).
    Dans phpMyAdmin, tu crée un utilisateur root et tu lui assigne dans la case client : % (tout client)

    Pour terminer, je te conseille créé un utilisateur avec un autre nom que root ainsi qu'un vrai mot de passe qui aura accès qu'à la base dont tu à besoin.

    Bonne soirée

  3. #3
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    Bonsoir,

    une longue réponse perdue par fausse manip

    D'abord, merci pour ta réponse.

    Ensuite, je ne suis pas à même de te répondre au sujet de la configuration du serveur et du firewall ; je suis un simple développeur, et ces sujets, c'est une autre personne qui les gère.
    De même, je ne sais te répondre au sujet du choix de localhost, mais ça marche comme ça.

    Ensuite, ça fait à peine plus d'un mois que je me plonge dans ce code, mais les accès à la bdd MySql sont faits avec les fonctions xx_mysql et comme celles-ci sont dépréciées, j'ai entrepris de les remplacer. Je viens de réussir à faire tourner un code en PDO :
    Code php : 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
    <?php
    header('Content-type: text/html; charset=UTF-8');
    //// connexion
    include (((dirname(__DIR__))).'/new/MyPdo.php');
    try{
    	$bdd = new MyPdo();
    	// exécuter un select puis afficher les lignes
    	$sql='select * from `users` order by nom';
    	$qid = $bdd->prepare($sql);
    	$qid->execute();
    	while( $ligne=$qid->fetch(PDO::FETCH_OBJ) )
    		echo "name : ".$ligne->nom."  firstname : ".$ligne->prenom." <br/>";
    	$bdd=NULL;
    }
    catch(PDOException $e){
    	echo "argggggggggggggg".$e->getMessage();
    }
    ?>

    et MyPdo.php
    Code php : 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
    <?php
    error_reporting(E_ALL ^ E_DEPRECATED ^ E_NOTICE);
    ini_set('display_errors','1'); 
    // MyPDO
     // ls : la classe MyPdo hérite de la classe PDO (extends)
    class MyPdo extends PDO {
    	static public $DB_NAME = "su_dev_eis"; // ls : static public, je sais + pourquoi...
    	static public $HOST = "localhost";
    	static public $USER = $_SERVER["PHP_AUTH_USER"];
    	static public $PASS =$_SERVER["PHP_AUTH_PW"];
    // ls : le constructeur de MyPdo appelle le constructeur de PDO en lui passant ses paramètres	
    	function __construct() {
    	/* ls : la variable $pdo_options, ça date de ma formation de 2012 */ 
    	$pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    	$pdo_options[PDO::ATTR_EMULATE_PREPARES] = false;//important sur les configs récentes
    	$pdo_options[PDO::ATTR_DEFAULT_FETCH_MODE] = PDO::FETCH_OBJ;//pour le mode objet
    	$pdo_options[PDO::MYSQL_ATTR_INIT_COMMAND] = "SET NAMES utf8";//pour l'utf-8
     	/* ls : connexion PDO : on instancie la classe, qui dérive de la classe PDO (fournie par PHP5) (les paramètres pour wampserver sont host="localhost",
    	user="root" et pwd="") */
    	parent::__construct('mysql:host=' . MyPdo::$HOST . ';dbname=' . MyPdo::$DB_NAME, MyPdo::$USER,MyPdo::$PASS, $pdo_options);
    	}
    }
    // fin MyPDO
    ?>

    Ce code existait déjà ; je l'ai juste modifié un peu (user et pwd (prise en compte de ta remarque) et include de MyPdo.php (car il n'était pas dans le même répertoire)) mais je n'ose pas essayer ton conseil sur la création d'un utilisateur root dans phpMyAdmin, n'étant pas le gestionnaire de cet outil et craignant de faire une bêtise difficile à réparer.

    Si j'ai désormais une solution PDO, j'aimerais quand même faire tourner ça en mysqli procédural sachant que ça serait bien plus simple de passer de mysql à mysqli procédural qu'à PDO...

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour Laurent,
    1/ Tu peux supprimer les parenthèses inutiles :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    include ( dirname(__DIR__) . '/new/MyPdo.php' );
    N.B. Ajouter des espaces améliore la lisibilité et peut éviter des erreurs... d'inattention ( ta grande spécialité ).

    2/ Il manque 3 h :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    				echo "argggggggggggggghhh".$e->getMessage();


    3/ Vérifie que tu as activé mysqli sur Wamp :
    Wamp -> PHP -> Extensions PHP -> cocher (cliquer) "PHP_mysqli"

    4/ Cela dit...
    Citation Envoyé par laurentSc Voir le message
    Si j'ai désormais une solution PDO, j'aimerais quand même faire tourner ça en mysqli procédural sachant que ça serait bien plus simple de passer de mysql à mysqli procédural qu'à PDO...
    Si tu sais utiliser PDO, ne t'en prive pas !
    Et ce n'est pas plus compliqué.
    Dernière modification par Invité ; 26/12/2014 à 00h30.

  5. #5
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    Merci Jérôme pour ta réponse.

    Concernant les parenthèses, je suis d'accord, qu'il y en a qui servent à rien, mais ça marche quand même (la coloration syntaxique de Notepad++ me l'avait montré...)

    Pour le nombre de h manquants, ça se discute... (en fait, j'ai juste copier-coller une connexion à PDO déjà utilisée).

    Pour l'activation de mysqli, je ne pourrai regarder que demain, ayant déjà éteint mon 2e PC (celui qui contient le code (en fait celui qui peut se connecter à ce serveur du boulot)), mais justement, là, Wampserver n'est pas sur un PC mais sur ce serveur (ce n'est pas moi qui l'ai installé) et je n'ai pas l'interface habituelle qui me permettrait de vérifier les extensions : cela dit, j'ai accès aux différents fichiers de configuration (PHP, MySQL et APACHE) ; peut-on vérifier ça en regardant un fichier ?

  6. #6
    Invité
    Invité(e)
    Par défaut
    Dans le fichier php.ini :

    remplacer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ;extension=php_mysqli.dll
    par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    extension=php_mysqli.dll

  7. #7
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    Je viens (enfin) de regarder ; l'extension mysqli est déjà validée...

  8. #8
    Membre habitué
    Avatar de romuluslepunk
    Homme Profil pro
    Juste passioné
    Inscrit en
    Avril 2005
    Messages
    174
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Belgique

    Informations professionnelles :
    Activité : Juste passioné

    Informations forums :
    Inscription : Avril 2005
    Messages : 174
    Points : 154
    Points
    154
    Par défaut
    Bonjour,

    Celà doit venir d'une mauvaise configuration de connexion.
    Vois avec le responsable du serveur MySql afin de vérifier que tout est correct.

    Voilà peu, j'ai eu un problème avec Symfony qui utilise PDO.
    Exactement la même erreur que toi mais en faisant des test sans passer par PDO et symfony -> pas de problèmes.
    Après avoir cherché plusieurs jours, j'ai changé mont mode passe -> problème réglé !!!
    (je précise ce n'était pas une faute de frappe !)
    Mon mot de passe était une suite de chiffre qui commençait par 0.
    J'ai pas fait de test pour voir si une autre suite de chiffre qui commençait pas par 0 fonctionnait.
    Je doute que ton problème vienne de là, mais celà prend 2 minutes à vérifier....
    Voici le post que j'avait créé : http://www.developpez.net/forums/d14...lutot-domaine/

  9. #9
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    D'abord, merci de m'avoir répondu. Le mot de passe pour se connecter à la bdd est tout bête : comme je suis en local (pas vraiment, mais ça revient au même), c'est "root" (si j'étais vraiment en local, ça serait ""). Et ça, je ne peux pas le changer. Mais comme ça marche avec PDO, et que j'avais prévu un jour ou l'autre de tout mettre en PDO, je vais le faire plus vite que prévu...

  10. #10
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    J'ai abandonné MySQLi et suis en train de tout passer en PDO.

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

Discussions similaires

  1. [MySQL] Connexion impossible sur nouveau serveur
    Par pedrilito dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 16/05/2013, 13h33
  2. [Cohabitation]Peut-on intaller sur même serveur MySql/MSSql?
    Par ruellan dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 06/04/2006, 14h52
  3. connexion sur un serveur mysql chez un hebergeur
    Par aude_1603 dans le forum SQL Procédural
    Réponses: 8
    Dernier message: 17/02/2006, 10h35
  4. tracer les connexions web sur un serveur
    Par lutin511 dans le forum Développement
    Réponses: 2
    Dernier message: 28/06/2004, 23h36
  5. Paramétrer le nombre de connexion sur mon serveur Mysql
    Par Zerga dans le forum Installation
    Réponses: 2
    Dernier message: 12/12/2003, 19h21

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