Accès au manager - réservé aux membres

Navigation

Bouts de Codes PHP

Gestion des pages en cache

Informations sur le code source PHP

Ecrit par :  lamogere
Site de l'auteur Voir
Autres codes en PHP de l'auteur : [13] sources Voir
Date d'enregistrement du code le 27 Mai 2008 - Vu 2058 fois
Code source zippé: Télécharger le fichier ZIP
Impression: Imprimer le code
Ajouter la page à vos favoris

Description du code source

Informations sur le code source

Ce script contient les fonctions pour la gestion du cache. Si la date HTTP_IF_MODIFIED_SINCE est renseignée et que le cache n'a pas été modifié depuis cette date, on ne renvoie qu'un statut 304 (Not modified). Si les options le permettent le contenu de la page est compressé avant d'être envoyé.

La fonction get_cache_name permet de déterminer le nom du fichier cache en fonction de l'url. Les fichiers caches sont sauvegardés dans un répertoire /cache/ à la racine du site. L'url est encodé avec la fonction md5 pour constituer le nom du fichier suivi de l'extension .html.

La fonction delete_cache_file permet de supprimer le fichier cache en fonction de l'url.

La fonction start_buffer permet d'envoyer le fichier cache si il existe, si il date de moins de 24H et si le paramètre de la fonction est true. Elle doit être placée le plus haut possible dans le script (avant tout affichage de données). Il est possible de ne pas envoyer le fichier en cache en mettant false comme paramètre (par exemple pour remplacer le fichier cache).

La fonction end_buffer permet de sauvegarder le fichier cache si le paramètre de la fonction est true. Le contenu de la page est ensuite envoyée au navigateur. Elle doit être placée à la fin des scripts après la génération du contenu. Il est possible de ne pas sauvegarder le fichier cache en mettant false comme paramètre (par exemple quand la page a des paramètres POST)

La fonction gere_erreur peut être utilisée pour gérer les erreurs (par exemple MYSQL). Il faut l'appeler quand on est dans l'impossibilité de générer le contenu de la page. Elle envoie le fichier cache si il existe (même si il est périmé). Sinon une erreur 503 est renvoyée (Service temporairement indisponible) qui indique aux moteurs de recherche qu'il faut revenir 1H plus tard.

Code Source



.01
.02
.03
.04
.05
.06
.07
.08
.09
.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
.42
.43
.44
.45
.46
.47
.48
.49
.50
.51
.52
.53
.54
.55
.56
.57
.58
.59
.60
.61
.62
.63
.64
.65
.66
.67
.68
.69
.70
.71
.72
.73
.74
.75
.76
.77
.78
.79
.80
.81
.82
.83
.84
.85
.86
.87
.88
.89
.90
.91
.92
.93
.94
.95
.96
.97
.98
.99
.100
.101
.102
.103
.104
.105
.106
.107
.108
.109
.110
.111
.112
.113
.114
.115
.116
.117
.118
.119
.120
.121
.122
.123
.124
.125
.126
.127
.128
.129
.130
.131
.132
.133
.134
.135
.136
.137
.138
.139
.140
.141
.142
.143
.144
.145
.146
.147
.148
.149
.150
.151
.152
.153
.154
.155
.156
.157
.158
.159
.160
.161
.162
.163
.164
.165
.166
.167
.168
.169
.170
.171
.172
.173
.174
.175
.176
.177
.178
.179
.180
.181
.182
.183
.184
.185
.186
.187
.188
.189
.190
.191
.192
.193
.194
.195
.196
.197
.198
.199
.200
.201
.202
.203
.204
.205
.206
.207
.208
.209
.210
.211
.212
.213
.214
.215
.216
.217
.218
.219
.220
.221
.222
.223
.224
.225
.226
.227
.228
.229
.230
.231
.232
.233
.234
.235
 

<?php
/******************************************************************************/
/*                                                                            */
/*                       __        ____                                       */
/*                 ___  / /  ___  / __/__  __ _____________ ___               */
/*                / _ \/ _ \/ _ \_\ \/ _ \/ // / __/ __/ -_|_-<               */
/*               / .__/_//_/ .__/___/\___/\_,_/_/  \__/\__/___/               */
/*              /_/       /_/                                                 */
/*                                                                            */
/*                                                                            */
/******************************************************************************/
/*                                                                            */
/* Titre          : Gestion des pages en cache                                */
/*                                                                            */
/* URL            : http://www.phpsources.org/scripts395-PHP.htm              */
/* Auteur         : lamogere                                                  */
/* Date édition   : 27 Mai 2008                                               */
/* Website auteur : http://www.toplien.fr/                                    */
/*                                                                            */
/******************************************************************************/

// répertoire contenant les fichiers cache
define ('REPERTOIRE_CACHE'rtrim($_SERVER['DOCUMENT_ROOT'], '/') . '/cache/');
// durée de vie du cache en seconde : ici 24 heures
define('DUREE_CACHE'86400);

// détermine le nom du fichier cache en fonction de l'url
function get_cache_name($url) {
    return REPERTOIRE_CACHE md5($url) . '.html';
}

// supprime le fichier cache si il existe
function delete_cache_file($url) {
    $fichierCache get_cache_name($url);
    if (@file_exists($fichierCache)) { //si la page existe dans le cache
        @unlink($fichierCache);
    }
}

//envoi le cache
function send_cache($fichierCache) {
    $date_modif = @filemtime($fichierCache);
    if (!empty($_SERVER['HTTP_IF_MODIFIED_SINCE']) &&
        (strtotime(preg_replace('/;.*$/''', 
         $_SERVER['HTTP_IF_MODIFIED_SINCE'])) >= $date_modif)) {
        header('Status: 304 Not Modified'false304);
        header('Last-Modified: ' gmdate('D, d M Y H:i:s'$date_modif) . ' GMT');
        header('Expires: ' gmdate('D, d M Y H:i:s'$date_modif DUREE_CACHE) . 
' GMT');
        exit;
    } else {
        header('Status: 200 OK'false200);
        header('Last-Modified: ' gmdate('D, d M Y H:i:s'$date_modif) . ' GMT');
    }
    while (ob_get_level()) ob_end_clean();
    if ((ini_get('zlib.output_compression') != true) && 
        function_exists('ob_gzhandler')) {
        ob_start('ob_gzhandler');
    } else {
        ob_start();
    } 
    if (@readfile($fichierCache) === false) { //si la page n'existe dans le cache
        while (ob_get_level()) ob_end_clean();
        die('Rechargez la page');
    }
    if ((ini_get('zlib.output_compression') == true) || 
        !function_exists('ob_gzhandler')) {
        header('Content-Length: ' ob_get_length());  
    }
    ob_end_flush();
}

// envoi le fichier cache si il existe, si il date de moins de 24H et si le
// paramètre $send_cache = true
// sinon commence la bufferisation du contenu (avec compression si possible)
function start_buffer($send_cache true) {
    $fichierCache get_cache_name('http://' $_SERVER['HTTP_HOST'] . $_SERVER[
'REQUEST_URI']);
    if ($send_cache && @file_exists($fichierCache) && @filemtime($fichierCache) > 
time() - DUREE_CACHE) {
        send_cache($fichierCache);
        exit;
    }
    ignore_user_abort(true);
    set_time_limit();
    while (ob_get_level()) ob_end_clean();
    if ((ini_get('zlib.output_compression') != true) && function_exists('ob_gzha' .
'ndler')) {
        ob_start('ob_gzhandler');
    } else {
        ob_start();
    } 
}

// sauvegarde le fichier cache si $saveCache = true
// puis termine la bufferisation et envoi le contenu au navigateur
function end_buffer($saveCache true) {
    if ($saveCache) {
        $fichierCache get_cache_name('http://' $_SERVER['HTTP_HOST'] . $_SERVER[
'REQUEST_URI']);
        if ($fd fopen($fichierCache'w')) {
            fwrite($fdob_get_contents()); // on ecrit le contenu du buffer dans le
// fichier cache
            fclose($fd);
        }
        $date_modif = @filemtime($fichierCache);
        header('Last-Modified: ' gmdate('D, d M Y H:i:s'$date_modif) . ' GMT');
        header('Expires: ' gmdate('D, d M Y H:i:s'$date_modif DUREE_CACHE) . 
' GMT');
    } else {
        header('Last-Modified: ' gmdate('D, d M Y H:i:s') . ' GMT');
    }
    if ((ini_get('zlib.output_compression') == true) || !function_exists('ob_gzh' .
'andler')) {
        header('Content-Length: ' ob_get_length());  
    }
    ob_end_flush();
}

// cette fonction est a appeler en cas d'erreur pour générer le contenu de la
// page (par exemple pour l'accès à la base de données)
// si le fichier existe en cache on envoie ce fichier sinon on envoie une
// erreur
// 503 (reessayer plus tard).
function gere_erreur() {
    $fichierCache get_cache_name('http://' $_SERVER['HTTP_HOST'] . $_SERVER[
'REQUEST_URI']);
    if (@file_exists($fichierCache)) {
        send_cache($fichierCache);
    } else {
        while (ob_get_level()) ob_end_clean();  // vide le buffer de sortie
        header('Status: 503 Service Temporarily Unavailable'false503);
        header('Retry-After: 3600'); // 1 heure
?>
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html>
<head>
<title>503 Service Temporarily Unavailable</title>
<meta name="robots" content="none">
</head>
<body>
<h1>Service Temporarily Unavailable</h1>
<p>The server is temporarily unable to service your
request due to maintenance downtime or capacity
problems. Please try again later.</p>
<h1>Service Temporairement indisponible</h1>
<p>Le serveur est temporairement incapable de
répondre à votre requête à cause d'un arrêt du
serveur pour maintenance ou problème.</p>
</body>
</html>
<?php
    }
    exit;
}
?>
<?php
// ce qui suit n'est là que pour servir d'exemple

if (isset($_GET['delete'])) {
    delete_cache_file($_GET['url']);
    header('Status: 301 Move permanently'false301);
    header('Location: ' $_GET['url']);
    exit;
}

start_buffer();
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
 "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>Test gestion cache</title>
</head>
<body>
<p>Ce script contient les fonctions pour la gestion du cache. 
Si la date HTTP_IF_MODIFIED_SINCE est renseignée et que le cache n'a pas été
 modifié depuis
cette date, on ne renvoie qu'un statut 304 (Not modified). 
Si les options le permettent le contenu de la page est compressé avant d'être
 envoyé.</p>
<p>La fonction <strong>get_cache_name</strong> permet de déterminer le nom du
 fichier cache en fonction de l'url. 
Les fichiers caches sont sauvegardés dans un répertoire /cache/ à la racine du
 site (<?php echo REPERTOIRE_CACHE;?>). 
L'url est encodé avec la fonction md5 pour constituer le nom du fichier suivi de
 l'extension .html.
Cette page sera sauvegardée par exemple avec le nom 
<?php echo get_cache_name('http://' $_SERVER['HTTP_HOST'] . $_SERVER[
'REQUEST_URI']); ?></p>
<p>La fonction <strong>delete_cache_file</strong> permet de supprimer le fichier
 cache en fonction de l'url.</p>
<p>La fonction <strong>start_buffer</strong> permet d'envoyer le fichier cache
 si il existe, si il date de moins de 24H
et si le paramètre de la fonction est true. Elle doit être placée le plus haut
 possible dans le script
appelé (avant tout affichage de données). Il est possible de ne pas envoyer le
 fichier en cache en 
mettant false comme paramètre (par exemple pour remplacer le fichier cache).</p>
<p>La fonction <strong>end_buffer</strong> permet de sauvegarder le fichier
 cache si le paramètre de la fonction
est true. Le contenu de la page est ensuite envoyée au navigateur. Elle doit
 être placée à la fin des
scripts après la génération du contenu. Il est possible de ne pas sauvegarder le
 fichier cache
en mettant false comme paramètre (par exemple quand la page a des paramètres
 POST)</p>
<p>La fonction <strong>gere_erreur</strong> peut être appelée en cas d'erreurs
 (par exemple MYSQL). 
Il faut l'appeler quand on est dans l'impossibilité de générer le contenu de la
 page. 
Elle envoie le fichier cache si il existe (même s'il est périmé). Sinon une
 erreur 503 est renvoyée
(Service temporairement indisponible) qui indique aux moteurs de recherche qu'il
 faut revenir
1H plus tard.</p>
<p><a href="cache.php">Rechargez cette page</a> pour voir la version en cache.
 La date et l'heure ci dessous ne doivent pas changer.</p>
<p><a href="cache.php?delete&url=<?php echo urlencode('http://' $_SERVER[
'HTTP_HOST'] . $_SERVER['REQUEST_URI']); ?>">Supprimer le cache</a> pour voir la
 date
 changer.</p>
<p><?php echo gmdate('D, d M Y H:i:s') . ' GMT'?></p>
<?php 
// on créé le répertoire cache si il n'existe pas.
if (!@file_exists(REPERTOIRE_CACHE)) {
    @mkdir(REPERTOIRE_CACHE);
}
?>
</body>
</html>
<?php
end_buffer();
?>

Fonctions du code source

Fonctions php / mysql PHP

  • define : Définit une constante - (PHP 4, PHP 5)
  • rtrim : -
  • md5 : Calcule le md5 d'une chaîne - (PHP 4, PHP 5, PECL hash:1.1-1.3)
  • file_exists : Vérifie si un fichier ou un dossier existe - (PHP 4, PHP 5)
  • unlink : Efface un fichier - (PHP 4, PHP 5)
  • filemtime : Lit la date de dernière modification du fichier - (PHP 4, PHP 5)
  • empty : Détermine si une variable contient une valeur non nulle - (PHP 4, PHP 5)
  • preg_replace : Rechercher et remplacer par expression rationnelle standard - (PHP 4, PHP 5)
  • strtotime : - (PHP 4, PHP 5)
  • header : Envoie un en-tête HTTP - (PHP 4, PHP 5)
  • gmdate : Formate une date/heure GMT/CUT - (PHP 4, PHP 5)
  • exit : Affiche un message et termine le script courant - (PHP 4, PHP 5)
  • ob_end_clean : Détruit les données du tampon de sortie et éteint la tamporisation de sortie - (PHP 4, PHP 5)
  • ob_get_level : Retourne le nombre de niveaux d'imbrications du système de tamporisation de sortie - (PHP 4 >= 4.2.0, PHP 5)
  • ini_get : Lit la valeur d'une option de configuration - (PHP 4, PHP 5)
  • function_exists : Indique si une fonction est définie - (PHP 4, PHP 5)
  • ob_start : Enclenche la tamporisation de sortie - (PHP 4, PHP 5)
  • readfile : Affiche un fichier - (PHP 4, PHP 5)
  • die : Alias de la fonction exit() - (PHP 4, PHP 5)
  • ob_get_length : Retourne la longueur du contenu du tampon de sortie - (PHP 4 >= 4.0.2, PHP 5)
  • ob_end_flush : Envoie les données du tampon de sortie et éteint la tamporisation de sortie - (PHP 4, PHP 5)
  • time : Retourne le timestamp UNIX actuel - (PHP 4, PHP 5)
  • ignore_user_abort : Active l'interruption de script sur déconnexion du visiteur - (PHP 4, PHP 5)
  • set_time_limit : Fixe le temps maximum d'exécution d'un script - (PHP 4, PHP 5)
  • fopen : Ouvre un fichier ou une URL - (PHP 4, PHP 5)
  • fwrite : Écrit un fichier en mode binaire - (PHP 4, PHP 5)
  • ob_get_contents : Retourne le contenu du tampon de sortie - (PHP 4, PHP 5)
  • fclose : Ferme un fichier - (PHP 4, PHP 5)
  • isset : Détermine si une variable est affectée - (PHP 4, PHP 5)
  • echo : Affiche une chaîne de caractères - (PHP 4, PHP 5)
  • urlencode : Encode une chaîne en URL - (PHP 4, PHP 5)
  • mkdir : Crée un dossier - (PHP 4, PHP 5)

Commentaire [1]

netphotos
le 20/06/2008 à 15:24:00
moi spécialement j'utilise celle ci qui est tres simple d'utilisation

<?php
// Du code php à ne pas mettre en cache (dates, variables de session...)

// Le script de mise en cache
$pageurl = ereg_replace('/','-',$_SERVER['REQUEST_URI']);
if($pageurl === '-'){ $pageurl = '-index.html'; }
$cachedir = 'cache/'.$pageurl;
if(@filemtime($cachedir)<time()-(3600*24*14)) {
ob_start();

// Le contenu de votre page à mettre en cache ici
echo '<html>...</html>';

// La suite du script de mise en cache
$cachecontent = ob_get_contents();
ob_end_flush();
$fd = fopen($cachedir,'w');
if($fd){
fwrite($fd,$cachecontent);
fclose($fd);
}
} else {
include($cachedir);
}
?>

Poster un commentaire

:P :) :wink: :lol: :surprised: :confused: :mad: :no:
Taille du texte:
Couleur:
Code de sécurité

Les dernières offres d'emploi