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 :

erreur que je ne comprend pas


Sujet :

PHP & Base de données

  1. #1
    Membre habitué
    Homme Profil pro
    retraité
    Inscrit en
    Mars 2003
    Messages
    397
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Mars 2003
    Messages : 397
    Points : 165
    Points
    165
    Par défaut erreur que je ne comprend pas
    Bonjour,

    Voici le code
    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
     
    require_once('../connex_mysqli/connex_base_gene.php');
     
    		$_SESSION["lig_timb"]=4;
    		$test=$_GET['lig'];
    		$query = 'SELECT id FROM collec_0 WHERE id='.$test;
    		$result = mysqli_query($base_gene, $query);
    		while ($row = mysqli_fetch_array($result))
    		{
    			if($row['id']==$test) 
    			 {
    				$_SESSION["lig_timb"]=$row['id'];
    				$suite=1;
    				break;
    			 }	 	
    		}
    mysqli_free_result($result); 		
    mysqli_close($base_gene);
     
    if($suite==1)
    {
    require_once('../connex_mysqli/connex_base_gene.php');
     
    $query = "SELECT id FROM collec_0";
    $result = mysqli_query($base_gene, $query);
    $nb_ligne = mysqli_num_rows($result)+1;
    mysqli_free_result($result); 		
    mysqli_close($base_gene);
    Erreur générée
    Couldn't fetch mysqli in ligne 25

    Je précise ces scripts sont inclus en tête d'une une page précédente qui ne comporte pas de connexion à la base
    en gros c'est foutu comme ça

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <?php
    include('../script/select_page_timbre.php'); // "c'est la page ou se situe l'erreur"
    $stop_pub=0;
    ?>
    <!DOCTYPE html>
    Merci pour votre aide

  2. #2
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 497
    Points : 12 600
    Points
    12 600
    Par défaut
    Vous devez récupérer les resultats avec un fecth


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $query = "SELECT id FROM collec_0";
    $stmt = mysqli_query($base_gene, $query);
     
    $result = mysqli_fetch_all($stmt, MYSQLI_ASSOC);
     
     
    $nb_ligne = mysqli_num_rows($result)+1;
    mysqli_free_result($result); 		
    mysqli_close($base_gene);

  3. #3
    Membre habitué
    Homme Profil pro
    retraité
    Inscrit en
    Mars 2003
    Messages
    397
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Mars 2003
    Messages : 397
    Points : 165
    Points
    165
    Par défaut
    Bonjour,
    Merci pour votre réponse mais j'ai toujours la même erreur

    Warning: mysqli_query(): Couldn't fetch mysqli in

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    require_once('../connex_mysqli/connex_base_gene.php');
     
    $query = "SELECT id FROM collec_0";
    $stmt = mysqli_query($base_gene, $query);
     
    $result = mysqli_fetch_all($stmt, MYSQLI_ASSOC);
     
     
    $nb_ligne = mysqli_num_rows($result)+1;
    mysqli_free_result($result); 		
    mysqli_close($base_gene);

  4. #4
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 497
    Points : 12 600
    Points
    12 600
    Par défaut
    Est-ce que votre requête fonctionne dans votre ide de DB (PhpMyAdmin, DBEaver ou autres ) ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT id FROM collec_0

  5. #5
    Membre habitué
    Homme Profil pro
    retraité
    Inscrit en
    Mars 2003
    Messages
    397
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Mars 2003
    Messages : 397
    Points : 165
    Points
    165
    Par défaut
    Merci pour vos réponses
    Je crois que j'ai trouvé
    j'ai remplacé le require_once('../connex_mysqli/connex_base_gene.php');

    par les données de connexion et là ça marche ?

    Pourquoi ? je ne sais pas.

    Bonne journée

  6. #6
    Membre expert
    Avatar de cavo789
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2004
    Messages
    1 792
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 792
    Points : 3 061
    Points
    3 061
    Par défaut
    Bonsoir

    Citation Envoyé par michel71 Voir le message
    Je crois que j'ai trouvé
    j'ai remplacé le require_once('../connex_mysqli/connex_base_gene.php');
    par les données de connexion et là ça marche ?
    Tu as supprimé le require et tu as mis le code à la place ? A priori, je dirais alors que ton chemin d'accès n'était pas correct et, du coup, le fichier non trouvé.

    Sinon, est-ce que ton code ressemble toujours à

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $test=$_GET['lig'];
    $query = 'SELECT id FROM collec_0 WHERE id='.$test;
    Parce que tu as un réel souci de sécurité du coup. Tu reçois un paramètre "lig" en URL que tu ne vérifies pas le moins du monde avant de l'utiliser.

    Il ne faut jamais faire confiance aux variables sans les tester.

    Si j'utilise "105 OR 1=1" comme valeur pour &lig, du coup je vais recevoir tout le contenu de ta table collec_0, là où tu pensais ne retourner qu'un seul résultat.
    Et ça, c'est une SQL injection gentille... On peut supprimer la table ou carrément ta base de données.

    Bonne soirée

  7. #7
    Membre habitué
    Homme Profil pro
    retraité
    Inscrit en
    Mars 2003
    Messages
    397
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Mars 2003
    Messages : 397
    Points : 165
    Points
    165
    Par défaut
    Bonjour,

    merci pour la réponse.
    La variable "get" est systématiquement vérifiée (je n'ai pas mis le code complet)
    par exemple je vérifie que le contenu est numérique etc...

  8. #8
    Expert éminent Avatar de CosmoKnacki
    Homme Profil pro
    Justicier interdimensionnel
    Inscrit en
    Mars 2009
    Messages
    2 899
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Justicier interdimensionnel

    Informations forums :
    Inscription : Mars 2009
    Messages : 2 899
    Points : 6 674
    Points
    6 674
    Par défaut
    Le problème vient bien de require_once qui, comme son nom l'indique, n'inclura un même fichier qu'une seule fois par script (contrairement à require ou include). Or, dans ton script tu essaies d'inclure deux fois la même chose: require_once('../connex_mysqli/connex_base_gene.php'); (ligne 2 et ligne 22). Donc à la ligne 22, le fichier n'est pas inclus.

    D'un autre coté, pourquoi vouloir absolument clore la connexion au serveur MySQL en cours de script alors que tu en as encore besoin?

Discussions similaires

  1. [Tableaux] Une erreur que je ne comprend pas
    Par bibom dans le forum Langage
    Réponses: 2
    Dernier message: 01/08/2006, 18h47
  2. [debug] erreur que je ne comprend pas
    Par PoZZyX dans le forum Java ME
    Réponses: 4
    Dernier message: 11/07/2006, 08h05
  3. std ::vector [erreur que je ne comprend pas]
    Par aaronw dans le forum SL & STL
    Réponses: 8
    Dernier message: 05/03/2006, 21h00
  4. [Débutant] Message d'erreur que je ne comprends pas
    Par Le Furet dans le forum Langage
    Réponses: 2
    Dernier message: 25/02/2006, 17h37
  5. [PostGreSQL] une erreur que je ne comprends pas
    Par flo78 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 02/02/2006, 10h18

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