Redirection d'une page en php

sunev -  
yg_be Messages postés 23437 Date d'inscription   Statut Contributeur Dernière intervention   -
Bonjour a tous et bonne année, bonne santé et tout le reste.

Sur une page protégée par un mot de passe qui redirige vers cette page si ce mot de passe est correct,
dont le code est:

<?php
if (isset($_POST['mot_de_passe']) AND $_POST['mot_de_passe'] == "login"){
// Si le mot de passe est bon
header('Location: pages_securisees.php'); //redirige vers la pages_securisees.php
}
else { // Sinon, on affiche un message d'erreur
echo '<div;><span style="font-size:14pt;"> Mot de Passe incorrect</span></div>';
}
?>

Ce code fonctionne très bien en local, la page: pages_securisees.php s'ouvre.
Par contre sur le serveur de mon site hébergé chez free il s'affiche ce message d'erreur:

Warning: Cannot modify header information - headers already sent by (output started at /mnt/169/sda/0/c/mon_sites/mot_de_login.php:8) in /mnt/169/sda/0/c/mon_sites/mot_de_login.php on line 33

Même avec l'adresse complète http//:monsite/pages_securisees.php c'est pareil.
Si quelqu'un a une idée d’où vient l'erreur, merci de m'en indiquer la raison'
ou éventuellement une autre astuce pour que ça fonctionne.

3 réponses

  1. NHenry Messages postés 15235 Date d'inscription   Statut Modérateur Dernière intervention   387
     
    Tu as des caractères avant le premier <
    Des retours à la ligne ou le marqueur UTF-8 (cas très courants)
    0
  2. SKYMWebDev Messages postés 193 Statut Membre 176
     
    Ca arrive (normalement) quand tu mets du code html avant avoir mis le header.

    Essaye ca:
    (par contre il faut mettre
    ob_start();
    au tout début de la page et
    ob_end_flush();
    tout a la fin...)

    <?php
    //retient les informations
    ob_start();
    
        if (isset($_POST['mot_de_passe']) AND $_POST['mot_de_passe'] ==  "login"){  
                                                         // Si le mot de passe est bon
        header('Location: pages_securisees.php');  //redirige vers la pages_securisees.php
    }
        else {                                     // Sinon, on affiche un message d'erreur
        echo '<div;><span style="font-size:14pt;"> Mot de Passe incorrect</span></div>';
    }
    
    //relache les infos
    ob_end_flush();
    ?>
    


    Sinon tu peux protéger ta page par un fichier .htaccess, voir https://openclassrooms.com/fr/courses/918836-concevez-votre-site-web-avec-php-et-mysql/918580-protegez-un-dossier-avec-un-htaccess
    0
  3. yg_be Messages postés 23437 Date d'inscription   Statut Contributeur Dernière intervention   Ambassadeur 1 588
     
    Qu'as tu dans les lignes 1 à 33 de mot_de_login.php?
    0