Je vais vous expliquer ici comment faire pour créer une page d'erreur personnalisée, comme celle du SdZ.
Exemple : allez sur
http://www.siteduzero.com/dkljd, ça va vous afficher une erreur 404, ou alors quand le Site du Zér0 est saturé, c'est l'erreur 500.
C'est un truc assez court, mais c'est bien pratique !
Matériel nécessaire :
- Des ciseaux
- Un crayon
- De la colle
- Une gomme
- Une hébergeur acceptant le php et les .htaccess.
Créez maintenant un fichier
.htaccess que vous placerez à la
racine de votre site, et insérez ceci : (en changeant bien sûr,
http://www.siteduzero.com par l'adresse de votre site web)
Code : Apache 1
2
3
4
5
6
7
8
9
10
11
12 | ErrorDocument 400 http://www.siteduzero.com/400.php
ErrorDocument 401 http://www.siteduzero.com/401.php
ErrorDocument 402 http://www.siteduzero.com/402.php
ErrorDocument 403 http://www.siteduzero.com/403.php
ErrorDocument 404 http://www.siteduzero.com/404.php
ErrorDocument 405 http://www.siteduzero.com/405.php
ErrorDocument 500 http://www.siteduzero.com/500.php
ErrorDocument 501 http://www.siteduzero.com/501.php
ErrorDocument 502 http://www.siteduzero.com/502.php
ErrorDocument 503 http://www.siteduzero.com/503.php
ErrorDocument 504 http://www.siteduzero.com/504.php
ErrorDocument 505 http://www.siteduzero.com/505.php
|
Mettez les liens en absolu pour l'instant, nous allons voir dans quel cas les utiliser en relatif.
C'est bien beau les 400, 401, 402, 403, 404, 500... mais ça veut dire quoi ?
Maintenant, vous devez vous dire : "je mets quoi dans 401.php... ?".
Vous y mettez ce que vous voulez.
Exemple pour 401.php : "vous avez tapé un mauvais pseudo / password".
Exemple pour 404.php : "page non trouvée".
Vous l'aurez compris, les erreurs en 400 sont des erreurs du client, et les 500, du serveur, je vous laisse mettre en forme tout ça

!
Le problème, c'est que ça va renvoyer vers une autre erreur : l'erreur 200 (page qui s'est correctement chargée) ; donc, je ne sais pas si on peut l'appeler "erreur".
Donc, avec les sites de référencement ayant un robot, comme Google ou MSN Search, il y a un léger problème : le moteur de recherche n'est pas en capacité de distinguer si la page est une page d'erreur ou non, il affichera alors plein de liens vers des pages d'erreurs lors d'une recherche.
Code : Apache 1
2
3
4
5
6
7
8
9
10
11
12 | ErrorDocument 400 /400.php
ErrorDocument 401 /401.php
ErrorDocument 402 /402.php
ErrorDocument 403 /403.php
ErrorDocument 404 /404.php
ErrorDocument 405 /405.php
ErrorDocument 500 /500.php
ErrorDocument 501 /501.php
ErrorDocument 502 /502.php
ErrorDocument 503 /503.php
ErrorDocument 504 /504.php
ErrorDocument 505 /505.php
|
Vous pouvez également faire un petit message, sans créer une nouvelle page, comme ceci :
Code : Apache 1
2
3
4
5
6
7
8
9
10
11
12 | ErrorDocument 400 "Echec de l'analyse HTTP"
ErrorDocument 401 "Mauvais pseudo/password"
ErrorDocument 402 "Le client doit reformuler sa demande avec les bonnes données de paiement."
ErrorDocument 403 "..."
ErrorDocument 404 ""
ErrorDocument 405 ""
ErrorDocument 500 ""
ErrorDocument 501 ""
ErrorDocument 502 ""
ErrorDocument 503 ""
ErrorDocument 504 ""
ErrorDocument 505 ""
|
Vous l'aurez compris : entre les guillemets, vous devez mettre le message d'erreur.
Mais c'est énervant de devoir créer une nouvelle page à chaque fois ! Eh bien vous pouvez en créer une seule qui contienne toutes les erreurs avec du php ; regardez :
(.htaccess)
Code : Apache 1
2
3
4
5
6
7
8
9
10
11
12 | ErrorDocument 400 /erreur.php?erreur=400
ErrorDocument 401 /erreur.php?erreur=401
ErrorDocument 402 /erreur.php?erreur=402
ErrorDocument 403 /erreur.php?erreur=403
ErrorDocument 404 /erreur.php?erreur=404
ErrorDocument 405 /erreur.php?erreur=405
ErrorDocument 500 /erreur.php?erreur=500
ErrorDocument 501 /erreur.php?erreur=501
ErrorDocument 502 /erreur.php?erreur=502
ErrorDocument 503 /erreur.php?erreur=503
ErrorDocument 504 /erreur.php?erreur=504
ErrorDocument 505 /erreur.php?erreur=505
|
Après, on va voir quelle est l'erreur qu'on affiche par rapport à la valeur du
GET erreur.
(erreur.php)
Code : PHP 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
36
37
38
39
40
41
42
43 | <?php
switch($_GET['erreur'])
{
case '400':
echo 'Echec de l\'analyse HTTP';
break;
case '401':
echo 'Le pseudo et/ou le mot de passe n\'est pas correct !';
break;
case '402':
echo 'Le client doit reformuler sa demande avec les bonnes données de paiement.';
break;
case '403':
echo 'Requête interdite !';
break;
case '404':
echo 'La page n\'existe pas ou n\'existe plus !';
break;
case '405':
echo 'Méthode non autorisée';
break;
case '500':
echo 'Erreur interne au serveur ou serveur saturé';
break;
case '501':
echo 'Le serveur ne supporte pas le service demandé';
break;
case '502':
echo 'Mauvaise passerelle';
break;
case '503':
echo ' Service indisponible';
break;
case '504':
echo 'Trop de temps à la réponse ';
break;
case '505':
echo 'Version HTTP non supportée ';
break;
default:
echo 'Erreur !!';
}
?>
|
Comme dit plus haut, il y a un risque que vos pages d'erreurs soient référencées dans les moteurs de recherches, nous allons donc leur interdire l'accès.
Méthode
Nous allons implanter un fichier
robots.txt à la racine de notre site
Il aura pour but de dire à tel ou tel robot de ne pas visionner telle ou telle page.
Voici comment se présente ce fichier :
Code : Autre - robots.txt
Dans
User-Agent, vous mettrez la liste des robots que vous voulez interdire, mais ici, nous allons utiliser l'étoile (*) qui va interdire l'accès à tous les robots.
Et dans
Disallow, vous mettrez la liste des pages à interdire, les unes après les autres, en réécrivant
Disallow pour chaque page.
Code : Autre - robots.txt1
2
3
4
5
| User-Agent: *
Disallow: /400.php
Disallow: /401.php
Disallow: /402.php
Disallow: /403.php |
STOP ! Je vais pas toutes les mettre alors qu'il y a une trentaine d'erreurs qui existent si ?
Non en effet, vous pouvez interdire l'accès à
tout un dossier, donc, je vous conseille vivement de mettre ces pages dans un dossier à part de ne pas oublier de changer l'URI/URL que vous avez mis dans le fichier
.htaccess.
Pour interdire l'accès à un dossier, pas de mystères, cela se passe comme pour les fichiers.
Code : Autre - robots.txt1
2
| User-Agent: *
Disallow: /nom_du_dossier_ou_se_trouvent_les_erreurs/ |
Tout de suite plus lisible n'est-ce pas ?
Ces annexes vont vous permettre de comprendre quelques petites choses qui auraient pu être incomprises ou mal comprises.
Annexe 1 : Racine du site
Explication
La racine du site est le lieu mère de votre site, c'est là où le visiteur arrive lorsque qu'il tape l'adresse du site dans sa barre d'adresse (ce qui suppose qu'il n'y ait au préalable aucune redirection).
Exemples d'arborescences
Si vous possédez un hébergement mutualisé, vous n'aurez accès qu'à une partie restreinte du serveur. Par exemple, pour Linux, vous pourriez avoir accès à la partie : /home/www/heberg_id_674123/.
Seule la partie après heberg_id_674123 vous sera visible, aucun accès ne vous sera autorisé dans un dossier parent.
Les hébergeurs ont plusieurs solutions, soit il mettent le dossier heberg_id_674123 comme dossier racine du site, soit ils vont vous permettre de ne pas mettre de fichier dans la partie publique mais dans une partie privée.
Exemples :
/home/www/ [...]
................/heberg_id_674121/[...]
................/heberg_id_674122/[...]
................/heberg_id_674123/private
................................./public <- Racine du site
/home/www/ [...]
................/heberg_id_674121/[...]
................/heberg_id_674122/[...]
................/heberg_id_674123/
................................./www <- Racine du site
/home/www/ [...]
................/heberg_id_674121/[...]
................/heberg_id_674122/[...]
................/heberg_id_674123/ <- Racine du site
Annexe 2 : robots.txt
Le fichier robots.txt, est un fichier présent à la racine du site qui contient des règles pour les robots (de Google, Yahoo, etc.) qui viendraient sur votre site. Ce fichier est vérifié et respecté par tous les robots dignes de ce nom (les plus connus), mais beaucoup ne respectent pas ces règles, voire ne les lisent pas. Donc ne vous faites pas trop d'illusions concernant ce fichier, c'est respecté par une petite poignée de robots, mais pas par tous.