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

Langage PHP Discussion :

Affichage tronqué d'un champ [PHP 5.3]


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 96
    Points : 73
    Points
    73
    Par défaut Affichage tronqué d'un champ
    Bonjour,
    je débute dans PHP, mon souci est peut être tout simple.
    Je cherche à afficher le contenu d'un champ de ma base de données. Voici le script:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
      $query = "select nom, Adresse from benevoles where login='$_POST[login]' AND motpasse='$_POST[motpasse]'";
      $result = mysql_query($query);
      $row = mysql_fetch_row($result);
      @$_POST['essai']=$row[1];
    essai est un champ créé dans un form, de type text.
    Tout marche bien, sauf qu'il n'apparait à l'écran que le premier mot contenu dans le champ Adresse de la table

    Merci de votre aide

  2. #2
    Membre régulier Avatar de Jiraiya42
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    671
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 671
    Points : 114
    Points
    114
    Par défaut
    Salut,

    Fais plutôt comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $query = mysql_query("select nom, Adresse from benevoles where login='$_POST[login]' AND motpasse='$_POST[motpasse]'");
    $row = mysql_fetch_object($query);
    $essai=$row->Adresse;
    Et si tu veux afficher cette valeur dans le champ de ton formulaire tu ajoutes dans ta balise input :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    value="<?php echo $essai; ?>"
    J'espère avoir répondu à ta question.

    @+

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 96
    Points : 73
    Points
    73
    Par défaut
    ça marche, au détail près que mon champ contient le texte suivant avant que je lance la requete qui va écrire dedans

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <br /> <b>Notice</b>:  Undefined variable: essai in <b>C:\EasyPHP-5.3.2i\www\CeneDuJeudi\Index.php</b> on line <b>65</b><br />

  4. #4
    Membre régulier Avatar de Jiraiya42
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    671
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 671
    Points : 114
    Points
    114
    Par défaut
    Ce message d'erreur signifie que la variable $essai n'est pas renseignée. Tout en haut du formulaire, il faut inclure le fichier où se trouve le bout de code que je t'ai donné.

  5. #5
    Membre expert Avatar de RunCodePhp
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    2 962
    Détails du profil
    Informations personnelles :
    Localisation : Réunion

    Informations forums :
    Inscription : Janvier 2010
    Messages : 2 962
    Points : 3 947
    Points
    3 947
    Par défaut
    Salut

    Tout marche bien, sauf qu'il n'apparait à l'écran que le premier mot contenu dans le champ Adresse de la table
    C'est très étrange que tu obtienne des résultats, car ta requête comporte une erreur.
    Normalement, il n'est pas possible de mettre directement $_POST['login'] et $_POST['motpasse'] comme ça.


    Faudrait plutôt faire comme ceci :
    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
     
    $login = mysql_real_escape_string($_POST['login']);
    $motpasse = mysql_real_escape_string($_POST['motpasse']);
    $query = mysql_query("select nom, Adresse from benevoles where login = '$login' AND motpasse = '$motpasse'") or die('Erreur : '.mysql_error());
    $total = mysql_num_rows($query);
     
    if ((int)$total > 0) {
        $benevole = mysql_fetch_array($query);
    }
    else {
        // Erreur : Aucune donnée correspondante
    }
     
    // Pour afficher une donnée du tableau
    echo $benevole['Adresse']; 
     
    // Ou alors
    echo 'Adresse : '.$benevole['Adresse'].'<br />';
     
    // Ou dans une partie HTML
    <p><?php echo $benevole['Adresse'] ?></p>
    Tu remarqueras que j'ai rajouter la fonction mysql_real_escape_string(), qui est le minimum à faire pour protéger les données entrantes (venant de l'extérieur).
    De même un or die() au cas où il y aurait une erreur dans la requête.

    Attention tout de même à ne pas trop faire de fantaisie, du genre nom, Adresse.
    Un coup le champ commence par une minuscule (nom), pour l'autre c'est une majuscule (Adresse) ???

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 96
    Points : 73
    Points
    73
    Par défaut
    merci pour cette fonction mysql_escape_string. Etant totalement bizuth en PHP et MySql, j'ai tout à découvrir
    Ok pour la remarque sur les noms de champs.

    Par contre, la solution avec echo n'affiche pas le résultat au bon endroit sur l'écran, la solution de Jiraiya42 marche parfaitement

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

Discussions similaires

  1. Affichage tronqué d'un champ Access 2000
    Par krassi dans le forum VBA Access
    Réponses: 2
    Dernier message: 29/08/2007, 11h21
  2. Overflow Affichage tronqué
    Par eirmag dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 31/05/2006, 13h23
  3. Réponses: 9
    Dernier message: 09/01/2006, 12h10
  4. affichage des tupes des champs
    Par zidenne dans le forum Bases de données
    Réponses: 1
    Dernier message: 10/11/2005, 10h12
  5. affichage de TOUS les champs d'une table
    Par babulior dans le forum ASP
    Réponses: 6
    Dernier message: 28/06/2005, 15h33

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