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 :

afficher tous images blob dans une tableau


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Homme Profil pro
    Développeur Java
    Inscrit en
    Avril 2012
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Avril 2012
    Messages : 12
    Points : 12
    Points
    12
    Par défaut afficher tous images blob dans une tableau
    comment je peux modifier mon script pour au lieux d'aperçu une seul image blob il affiche tous les images blob dans une tableau.

    *SQL de base de donner "test"
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    CREATE TABLE `images` (
    `img_id` INT NOT NULL AUTO_INCREMENT ,
    `img_nom` VARCHAR( 50 ) NOT NULL ,
    `img_taille` VARCHAR( 25 ) NOT NULL ,
    `img_type` VARCHAR( 25 ) NOT NULL ,
    `img_desc` VARCHAR( 100 ) NOT NULL ,
    `img_blob` BLOB NOT NULL ,
    PRIMARY KEY ( `img_id` )
    )

    * les pages php
    index.php
    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
    <html>
    <head>
    <title>Stock d'images</title>
    </head>
    <body>
    <?php
    include ("transfert.php");
    if ( isset($_FILES['fic']) )
    {
    transfert();
    }
    ?>
    <h3>Envoi d'une image</h3>
    <form enctype="multipart/form-data" action="#" method="post">
    <input type="hidden" name="MAX_FILE_SIZE" value="250000" />
    <input type="file" name="fic" size=50 />
    <input type="submit" value="Envoyer" />
    </form>
    <p><a href="liste.php">Liste</a></p>
    </body>
    </html>
    transfert.php
    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    <?php
    function transfert ()
    {
    $ret = false;
    $img_blob = '';
    $img_taille = 0;
    $img_type = '';
    $img_nom = '';
    $taille_max = 250000;
    $ret = is_uploaded_file ($_FILES['fic']['tmp_name']);
    if ( !$ret )
    {
    echo "Problème de transfert";
    return false;
    }
    else
    {
    // Le fichier a bien été reçu
    $img_taille = $_FILES['fic']['size'];
    if ( $img_taille > $taille_max )
    {
    echo "Trop gros !";
    return false;
    }
    $img_type = $_FILES['fic']['type'];
    $img_nom = $_FILES['fic']['name'];
    include ("connexion.php");
    $img_blob = file_get_contents ($_FILES['fic']['tmp_name']);
    $req = "INSERT INTO images (".
    "img_nom, img_taille, img_type, img_blob ".
    ") VALUES (".
    "'".$img_nom."', ".
    "'".$img_taille."', ".
    "'".$img_type."', ".
    // N'oublions pas d'échapper le contenu binaire
    "'".addslashes ($img_blob)."') ";
    $ret = mysql_query ($req) or die (mysql_error ());
    return true;
    }
    }
    ?>
    liste.php
    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
    <html>
    <head><title>Stock d'images</title></head>
    <body>
    <?php
    include ("connexion.php");
    $req = "SELECT img_nom, img_id ".
    "FROM images ORDER BY img_nom";
    $ret = mysql_query ($req) or die (mysql_error ());
    while ( $col = mysql_fetch_row ($ret) )
    {
    echo "<a href=\"apercu.php?id=".$col[1].
    "\">".$col[0]."</a><br />";
    }
    ?>
    </body>
    </html>
    apercu.php
    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
    <?php
    if ( isset($_GET['id']) )
    {
    $id = intval ($_GET['id']);
    include ("connexion.php");
    $req = "SELECT img_id, img_type, img_blob ".
    "FROM images  ";
    $ret = mysql_query ($req) or die (mysql_error ());
    $col = mysql_fetch_row ($ret);
    if ( !$col[0] )
    {
    echo "Id d'image inconnu";
    }
    else
    {
    header ("Content-type: ".$col[1]);
    echo $col[2];
     
    }
    }
    else
    {
    echo "Mauvais id d'image";
    }
    ?>
    connexion.php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
    $hote = 'localhost';
    $base = 'test';
    $user = 'root';
    $pass = '';
    $cnx = mysql_connect ($hote, $user, $pass) or die (mysql_error ());
    $ret = mysql_select_db ($base) or die (mysql_error ());
    ?>

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Affichage de données dans un tableau - IV. Affichage "en ligne" avec Base de Données
    Tu as juste à faire l'affichage du blob à la place d'une simple chaine.
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Membre à l'essai
    Homme Profil pro
    Développeur Java
    Inscrit en
    Avril 2012
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Avril 2012
    Messages : 12
    Points : 12
    Points
    12
    Par défaut
    merci Celira mais qund je faire l'affichage "en ligne" j'ai comme resultat tableau du text (les noms des images)

Discussions similaires

  1. afficher un image située dans une dll
    Par idaram dans le forum Débuter
    Réponses: 2
    Dernier message: 07/02/2014, 14h50
  2. Réponses: 2
    Dernier message: 29/11/2009, 13h38
  3. afficher tous les âges dans une base ?
    Par sabredebois dans le forum Langage SQL
    Réponses: 3
    Dernier message: 23/01/2008, 09h26
  4. Afficher une image stockée dans un tableau de bytes
    Par ValyGator dans le forum Windows
    Réponses: 2
    Dernier message: 07/01/2007, 22h52
  5. [.NET][CR] Comment afficher une image blob dans un état ?
    Par moucrack dans le forum SAP Crystal Reports
    Réponses: 1
    Dernier message: 25/06/2005, 13h49

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