Bonsoir,

Je me demandais quelle était la manière la plus propre pour faire une redirection après par exemple une inscription.

Habituellement j'utilise

header('location:mapage.php');
exit();

Mais le problème c'est que ça provoque l'envoi d'un autre header.. et c'est donc problématique quand on utilise les sessions..
Sinon je vois ausis cette méthode :

echo "<META HTTP-EQUIV='refresh' CONTENT='2; URL=index.php'>";

Mais ça implique de mettre de l'HTML dans du PHP... Pas très propre selon moi..

Des avis ?

2 réponses


J'avais fait cette petite fonction perso y a moulte temps :

<?php

function redirect($to) {
        if(headers_sent())
            print('<meta http-equiv="refresh" content="0;url='.$to.'">');
        else
            header("Location: $to");
            exit;
}
?>

Bon, ça payait pas de mine mais c'était suffisant :)

Salut,

La méthode "header" de PHP te permet de transmettre des entêtes HTTP. C'est ce que j'utilise pour renvoyer vers un formulaire d'identication par exemple.

je renvoie un code 401 avant de rediriger.

Une autre grosse différence quand tu écris :

echo "<META HTTP-EQUIV='refresh' CONTENT='2; URL=index.php'>";

il peut y avoir du code PHP qui continue à s'executer. Par exemple :

echo "<META HTTP-EQUIV='refresh' CONTENT='2; URL=index.php'>";
/* -- J'ai encore 2 secondes pour executer du code PHP -- */

Au pire je ferais plutôt un

die( "<META HTTP-EQUIV='refresh' CONTENT='2; URL=index.php'>" );

Ma petit fonction perso :

/**
 * Redirige le navigateur vers le nouvelle URL avec l'entete qui correspond
 *
 * @param     $urlToRedirect
 * @param int $httpStatus
 */
function redirectTo($urlToRedirect, $httpStatus = 200)
{
    $messages = array(
        //Informational 1xx
        100 => '100 Continue',
        101 => '101 Switching Protocols',
        //Successful 2xx
        200 => '200 OK',
        201 => '201 Created',
        202 => '202 Accepted',
        203 => '203 Non-Authoritative Information',
        204 => '204 No Content',
        205 => '205 Reset Content',
        206 => '206 Partial Content',
        226 => '226 IM Used',
        //Redirection 3xx
        300 => '300 Multiple Choices',
        301 => '301 Moved Permanently',
        302 => '302 Found',
        303 => '303 See Other',
        304 => '304 Not Modified',
        305 => '305 Use Proxy',
        306 => '306 (Unused)',
        307 => '307 Temporary Redirect',
        //Client Error 4xx
        400 => '400 Bad Request',
        401 => '401 Unauthorized',
        402 => '402 Payment Required',
        403 => '403 Forbidden',
        404 => '404 Not Found',
        405 => '405 Method Not Allowed',
        406 => '406 Not Acceptable',
        407 => '407 Proxy Authentication Required',
        408 => '408 Request Timeout',
        409 => '409 Conflict',
        410 => '410 Gone',
        411 => '411 Length Required',
        412 => '412 Precondition Failed',
        413 => '413 Request Entity Too Large',
        414 => '414 Request-URI Too Long',
        415 => '415 Unsupported Media Type',
        416 => '416 Requested Range Not Satisfiable',
        417 => '417 Expectation Failed',
        418 => '418 I\'m a teapot',
        422 => '422 Unprocessable Entity',
        423 => '423 Locked',
        426 => '426 Upgrade Required',
        428 => '428 Precondition Required',
        429 => '429 Too Many Requests',
        431 => '431 Request Header Fields Too Large',
        //Server Error 5xx
        500 => '500 Internal Server Error',
        501 => '501 Not Implemented',
        502 => '502 Bad Gateway',
        503 => '503 Service Unavailable',
        504 => '504 Gateway Timeout',
        505 => '505 HTTP Version Not Supported',
        506 => '506 Variant Also Negotiates',
        510 => '510 Not Extended',
        511 => '511 Network Authentication Required'
    );

    $httpStatus = intval($httpStatus);
    if (!isset($messages[$httpStatus])) {
        $httpStatus = 302;
    }
    $protocol = (isset($_SERVER['SERVER_PROTOCOL']) ? $_SERVER['SERVER_PROTOCOL'] : 'HTTP/1.0');
    header_remove();
    http_response_code($httpStatus);
    header($protocol . ' ' . $messages[$httpStatus]);
    header("Location:" . $urlToRedirect);
    exit(0);
}

redirectTo("/user/ident-form", 401);

J'espère que ça va t'aider.

Pierre-Louis