Réponses:
Vous pouvez essayer la méthode mentionnée dans le billet de blog intitulé Quelques façons de déboguer mod_rewrite :
Fondamentalement, ce que vous faites est de vider certaines des informations que mod_rewrite utilise dans les en-têtes, puis d'utiliser les extensions Firebug ou LiveHTTP Headers dans Firefox pour regarder les en-têtes et lire vos informations de débogage.
Dans .htaccess, utilisez la condition et la règle:
RewriteCond %{QUERY_STRING} !vardump
RewriteRule (.*) http://www.example.com/$1?vardump&thereq=%{THE_REQUEST}&reqhost=%{HTTP_HOST} [R=301,L,QSA]
Essayez-les:
RewriteLog "/myfolder/mylogfile.log"
RewriteLogLevel 3
Ce ne sont que des expressions régulières avec quelques ajouts, vous pouvez donc utiliser Regex Coach pour les tests initiaux par rapport aux URL ou tout autre outil de débogage Regex.
À votre santé! :)
.htaccess
fichiers. Cela doit aller, httpd.conf
ce qui signifie qu'il n'est généralement pas réalisable sur les comptes d'hébergement partagé. :-(
Voici un petit hack intéressant pour "faire écho" des variables d'un fichier .htaccess.
Si AllowOverride est défini sur FileInfo, vous pouvez définir et déclencher une réponse d'erreur personnalisée dans votre fichier .htaccess avec les variables souhaitées dans la sortie:
ErrorDocument 404 "Request: %{THE_REQUEST} Referrer: %{HTTP_REFERER} Host: %{HTTP_HOST}"
RewriteRule ^ - [L,R=404]
Selon la façon dont vous êtes créatif avec les expressions, vous pouvez produire beaucoup d'informations utiles!
Vous n'êtes pas limité à utiliser le statut 404 sur votre contenu "en écho". Vous pouvez même remplacer le statut 200 "ErrorDocument" - qui, couplé à des <If>
directives, pourrait permettre d'autres utilisations assez intéressantes de ce hack pour renvoyer le contenu directement à partir d'un fichier .htaccess.