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 :

Forcer le téléchargement


Sujet :

Langage PHP

  1. #1
    Membre expérimenté
    Avatar de Gouyon
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2003
    Messages
    1 095
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 1 095
    Points : 1 531
    Points
    1 531
    Billets dans le blog
    5
    Par défaut Forcer le téléchargement
    Salut à tous

    J'ai récupéré dans la FAQ le moyen de forcer le téléchargement d'un fichier. Mais ça ne marche pas donc je dois faire une erreur quelque part 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
    29
    30
    31
    32
    33
    34
    35
     
     <?php
       session_start();
       $ID="NOWAY";
       $Pass="NOWAY";
       if(isset($_SESSION['nom']))
         {
           $ID=$_SESSION['nom'];
           if(isset($_SESSION['pass']))
             {
               $Pass=$_SESSION['pass'];
               if(!empty($_GET["Ref"]))
               {
                 $Ref=$_GET["Ref"];
                 $conn=mysql_connect("localhost",$ID,$Pass);
                 if($connection)
                   {
                     if(mysql_select_db("miramer"))
                       {
                         $sqlStatement = "SELECT Lien_Mes FROM miramer.t_mesures WHERE (Ref_Mes='{$Ref}')";
                         $result = mysql_query($sqlStatement);
                         if(mysql_num_rows($result)!=0)
                         {
                           $row="data/"+mysql_fetch_object($res);
                           header("Content-type: application/force-download");
                           header("Content-Length: ".filesize($row));
                           header("Content-Disposition: attachment; filename=".basename($row));
                           readfile($row);
                         }
                       }
                   }
               }
            }
         }
    ?>
    je l'appelle à partir d'un lien qui a comme paramètre le numéro de référence du fichier par exemple http:://MonSite/Telecharger2.php?Ref=3.

  2. #2
    Membre expert
    Avatar de ThomasR
    Homme Profil pro
    Directeur technique
    Inscrit en
    Décembre 2007
    Messages
    2 230
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2007
    Messages : 2 230
    Points : 3 972
    Points
    3 972
    Par défaut
    Bonjour,

    cela peut venir en partie du fait que le signe de concaténation est le "." et non le "+" et que mysql_fetch_object renvoie un objet, et non une string.

    Aussi, je trouve ta requête SQL un peu bizzare :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     $sqlStatement = "SELECT Lien_Mes FROM miramer.t_mesures WHERE Ref_Mes='".$Ref."'";
                         $result = mysql_query($sqlStatement);
                         if(mysql_num_rows($result)!=0)
                         {
                           $row="data/".mysql_result($result,0,"Lien_Mes");
                           header("Content-type: application/force-download");
                           header("Content-Length: ".filesize($row));
                           header("Content-Disposition: attachment; filename=".basename($row));
                           readfile($row);
                         }

  3. #3
    Membre expérimenté
    Avatar de Gouyon
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2003
    Messages
    1 095
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 1 095
    Points : 1 531
    Points
    1 531
    Billets dans le blog
    5
    Par défaut
    J'ai appliqué ta modif et ça n'a pas marché mais le problème venait de là
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $conn=mysql_connect("localhost",$ID,$Pass);
                 if($connection)
                   {
    Ah les joie du copier coller

    Maintenant ça fonctionne bien

    Par contre je ne vois pas en quoi ma requête SQL est bizarre

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 13/06/2007, 15h27
  2. [PHP-JS] Forcer le téléchargement d'une image JPG
    Par Amnesiak dans le forum Langage
    Réponses: 5
    Dernier message: 09/11/2006, 23h50
  3. [Configuration] problème pour forcer le téléchargement d'un fichier
    Par All Bran dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 3
    Dernier message: 02/01/2006, 16h23
  4. Réponses: 1
    Dernier message: 08/09/2005, 11h01
  5. Réponses: 2
    Dernier message: 23/03/2005, 08h51

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