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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    retraité
    Inscrit en
    Mars 2003
    Messages
    422
    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 : 422
    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 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 506
    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 éclairé
    Homme Profil pro
    retraité
    Inscrit en
    Mars 2003
    Messages
    422
    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 : 422
    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 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 506
    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 éclairé
    Homme Profil pro
    retraité
    Inscrit en
    Mars 2003
    Messages
    422
    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 : 422
    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 797
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 797
    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

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