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

Vue hybride

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    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 confirmé
    Avatar de romuluslepunk
    Homme Profil pro
    Juste passioné
    Inscrit en
    Avril 2005
    Messages
    174
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Belgique

    Informations professionnelles :
    Activité : Juste passioné

    Informations forums :
    Inscription : Avril 2005
    Messages : 174
    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
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    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
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    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

+ 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