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 :

header location qui ne fonctionne pas


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Homme Profil pro
    noobies
    Inscrit en
    Décembre 2014
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : noobies

    Informations forums :
    Inscription : Décembre 2014
    Messages : 103
    Par défaut header location qui ne fonctionne pas
    Bonjour,

    a la fin de mon script (qui fonctionne) le header ne fonctionne pas.

    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
    <?php
     
    require_once 'Classes/PHPExcel/IOFactory.php';
    include("db_connect.php");
    $id = $_GET['id'];
    $file = $_GET['fichier'];
     
     
     
    $inFile = 'xlsx/'.$file.'';
    $objReader = PHPExcel_IOFactory::createReader('Excel2007');
    $objPHPExcel = $objReader->load($inFile);
     
    $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'CSV');    
     
    $index = 0;
    foreach ($objPHPExcel->getWorksheetIterator() as $worksheet) {
     
        $objPHPExcel->setActiveSheetIndex($index);
     
        // write out each worksheet to it's name with CSV extension
        $outFile = str_replace(array("-"," "), "_", $worksheet->getTitle()) ."MVTS POUR LE 16-02.csv";
     
        $objWriter->setSheetIndex($index);
        $objWriter->save('csv/'.$outFile);
     
        $index++;
     
     
    }
    header('Location: encours.php?id='.$id.'');
    exit;
    ?>
    merci

  2. #2
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 322
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 322
    Billets dans le blog
    17
    Par défaut
    a la fin de mon script (qui fonctionne) le header ne fonctionne pas.
    C'est-à-dire ? Il y a un message d'erreur ?
    L'affichage des erreurs n'aurait pas été désactivé ?

    ...
    header('Location: encours.php?id='.$id.'');
    exit;
    ?>
    Une bonne pratique avec ce genre de script est de retirer la balise de fin ?> pour éviter les caractères non-imprimables qui viendraient se glisser en fin de script.

    Le conseil vaut pour tous les scripts inclus. Le moindre caractère envoyé au navigateur avant <?php ou après ?> va fausser header().

  3. #3
    Membre confirmé
    Homme Profil pro
    noobies
    Inscrit en
    Décembre 2014
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : noobies

    Informations forums :
    Inscription : Décembre 2014
    Messages : 103
    Par défaut
    merci,

    j'ai supprimé le ?> en fin mais aucune erreurs, page blanche, le csv se créé bien mais en fin de course il ne part pas sur l'autre page.

    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
    <?php
     
    require_once 'Classes/PHPExcel/IOFactory.php';
    include("db_connect.php");
    $id = $_GET['id'];
    $file = $_GET['fichier'];
     
     
     
    $inFile = 'xlsx/'.$file.'';
    $objReader = PHPExcel_IOFactory::createReader('Excel2007');
    $objPHPExcel = $objReader->load($inFile);
     
    $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'CSV');    
     
    $index = 0;
    foreach ($objPHPExcel->getWorksheetIterator() as $worksheet) {
     
        $objPHPExcel->setActiveSheetIndex($index);
     
        // write out each worksheet to it's name with CSV extension
        $outFile = str_replace(array("-"," "), "_", $worksheet->getTitle()) ."MVTS POUR LE 16-02.csv";
     
        $objWriter->setSheetIndex($index);
        $objWriter->save('csv/'.$outFile);
     
        $index++;
     
     
    }
    header('Location: impxlsx.php');
    merci

  4. #4
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 322
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 322
    Billets dans le blog
    17
    Par défaut
    On est bien d'accord que le CSV ne s'affiche/télécharge pas et que tu as juste une page blanche ?

    Si c'est bien le cas, fait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <?php
     
    require_once 'Classes/PHPExcel/IOFactory.php';
    echo '['
     
    ...
     
    echo ']';
    header('Location: impxlsx.php');
    Puis affiche la source de la page, et, attention il va falloir être précis, vérifie ce qu'il y a
    1. avant le [
    2. entre les [ ]
    3. après le ]

    Tout caractère blanc ou retour à la ligne ainsi détecté, ou quoi que ce soit d'autre, va gêner le header()

    Si tu as du mal à procéder ainsi, il faudra activer le rapport d'erreur => error_reporting(E_ALL) + init_set('display_error', '1')

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 30/08/2011, 11h59
  2. [PHP-JS] header() qui ne fonctionne pas
    Par Panther dans le forum Langage
    Réponses: 17
    Dernier message: 18/04/2007, 07h42
  3. [Cookies] Redirection Header qui ne fonctionne pas
    Par arnaudperfect dans le forum Langage
    Réponses: 10
    Dernier message: 20/03/2007, 09h19
  4. CREATEFILEMAPPING qui ne fonctionne pas???
    Par Jasmine dans le forum MFC
    Réponses: 2
    Dernier message: 06/01/2004, 19h33
  5. UNION qui ne fonctionne pas
    Par r-zo dans le forum Langage SQL
    Réponses: 7
    Dernier message: 21/07/2003, 10h04

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