IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Apache Discussion :

URL rewriting : je suis perdu !


Sujet :

Apache

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    581
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 581
    Points : 146
    Points
    146
    Par défaut URL rewriting : je suis perdu !
    Bonjour, j'ai eu beau lire et relire tout ce que je trouvais sur le sujet, je pense ne pas comprendre complètement le fonctionnement de l'URL rewriting.

    Je m'explique : à l'heure actuelle, les liens utilisés sur mon site sont de la forme www.monsite.fr/index.php?page=accueil ou www.monsite.fr/index.php?page=actu&id=5. Mon objectif est donc de mettre en place un .htaccess pour que mes urls soient de la forme www.monsite.fr/accueil ou www.monsite.fr/actu/5.

    Faut-il donc que je modifie tous mes <href> qui sont actuellement en <href="index.php?page=accueil"> en <href="accueil"> et que mon .htaccess décrypte le bon format, ou est-ce je doit laisser mes <href> comme ceci et faire en sorte que sur le navigateur le .htaccess affiche l'url modifiée ?

    Merci d'avance.

  2. #2
    Expert éminent sénior

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Points : 17 777
    Points
    17 777
    Par défaut
    La réécriture c'est le fait de faire rediriger de manière interne donc invisible pour le client une URL virtuelle (qui n'existe normalement pas) sur une autre. Ce processus s'arrête là, il ne modifie en rien le contenu de vos ressources (code HTML).

    Citation Envoyé par nicolas2603 Voir le message
    Faut-il donc que je modifie tous mes <href> qui sont actuellement en <href="index.php?page=accueil"> en <href="accueil"> et que mon .htaccess décrypte le bon format, ou est-ce je doit laisser mes <href> comme ceci et faire en sorte que sur le navigateur le .htaccess affiche l'url modifiée ?
    Il vous faut par conséquent modifier vos liens sinon la réécriture n'entrera jamais en jeu.

    Par contre, il est éventuellement possible de faire modifier dynamiquement votre code par un autre module Apache (comme mod_substitute), par PHP (en bufferisant la sortie et en traitant celle-ci ensuite - fonction ob_start et consœurs - un exemple), etc. Ces solutions peuvent permettre de minimiser les modifications à apporter à une application existante mais demandera plus de ressources et est susceptible d'introduire des "bugs", suivant la manière dont c'est implémenté.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    581
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 581
    Points : 146
    Points
    146
    Par défaut
    D'accord, donc la première chose à faire pour bien faire est de modifier toutes mes url au format www.monsite.fr/accueil. Pour ce genre de cas, ok mon .htaccess redirige correctement. Mais lorsque je tente un lien avec paramètres, ça ne fonctionne pas, par exemple www.monsite.fr/actu/5.html (url réelle www.monsite.fr/index.php?page=actu&id=5)...

    Mon .htaccess est comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Options FollowSymLinks
    RewriteEngine on
    RewriteRule ^([a-z]+)\.html$ index.php?page=$1 [L]
    RewriteRule ^([a-z]+)/([0-9]+)\.html$ index.php?page=$1&id=$2 [L]
    Quelle est mon erreur ?

  4. #4
    Expert éminent sénior

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Points : 17 777
    Points
    17 777
    Par défaut
    Les règles sont correctes si le but est de rediriger :
    • accueil.html (fictive) sur index.php?page=accueil (réelle) [application de la règle n°1]
    • actu/5.html (fictive) sur index.php?page=actu&id=5 (réelle) [application de la règle n°2]

    Remarquez que les ressources réécrites doivent être suffixées de .html conformément aux règles ci-dessus.

    Par contre il faudrait définir ne pas fonctionner. L'obtention d'une 404 signifiera que le fichier .htaccess n'est pas du tout pris en compte (AllowOverride à None au niveau du fichier de configuration d'Apache - je n'ai pas compris si ça pouvait être le cas ou non du post précédent) ou qu'il n'y a tout simplement pas correspondance par rapport à l'URL demandée (pas de relation URL/motif, .htaccess mal placé, conflit de règles, ...).

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    581
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 581
    Points : 146
    Points
    146
    Par défaut
    Oui j'ai une erreur 404.
    J'ai donc regardé dans mon fichier httpd.conf et je trouve 3 entrées AllowOverride, dont 2 à None (<Directory /> et <Directory "c:/Program/Wamp5/apache2/cgi-bin">) et 1 à All (Options Indexes FollowSymLinks).

    Il me semble que c'est cette dernière qui nous intéresse !

  6. #6
    Expert éminent sénior

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Points : 17 777
    Points
    17 777
    Par défaut
    Aucune règle ne fonctionne ? Quelle(s) URL(s) avez-vous essayé ? Le fichier .htaccess est-il donné tel qu'il est ? Peut-on avoir la trace de l'erreur 404 (journal d'erreur) ? Y a-t-il un alias qui entre en jeu ?

    Citation Envoyé par nicolas2603 Voir le message
    1 à All (Options Indexes FollowSymLinks)
    S'il correspond au répertoire représentant la racine (DocumentRoot) et qu'il n'y a pas utilisation d'Alias, cette configuration devrait ainsi permettra la réécriture.

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    581
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 581
    Points : 146
    Points
    146
    Par défaut
    Si la première règle fonctionne, avec l'url simple, mais celle lorsqu'il y a des paramètres ne fonctionne pas.

    • accueil.html (fictive) sur index.php?page=accueil (réelle) [application de la règle n°1] <- la redirection est ok
    • actu/5.html (fictive) sur index.php?page=actu&id=5 (réelle) [application de la règle n°2] <- erreur 404


    Voici mon .htaccess :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    #--------------------------------------------------
    # URL Rewriting
    #--------------------------------------------------
     
    # Le serveur doit suivre les liens symboliques :
    Options +FollowSymlinks
     
    # Activation du module de réécriture d'URL :
    RewriteEngine on
     
    # Pages sans paramètres :
    RewriteRule ^([a-z]+)\.html$ index.php?page=$1 [L]
    RewriteRule ^([a-z]+)/([0-9]+)\.html$ index.php?page=$1&id=$2 [L]
    Il n'y a pas d'alias qui rentre en jeu, en revanche, mes fichiers ne sont pas à la racine du localhost mais dans un dossier Internet. Ce qui n'empêche pas le 1er lien de fonctionner !!

    Quant à l'erreur 404 :
    "Not Found
    The requested URL /Internet/actu/5.html was not found on this server."

  8. #8
    Expert éminent sénior

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Points : 17 777
    Points
    17 777
    Par défaut
    S'il y a un répertoire /Internet/ intermédiaire les URLs (chemins plutôt) à réécrire sont donc de la forme /Internet/accueil.html et /Internet/actu/5.html ? Il est situé où le fichier .htaccess ? Quelle est la trace dans le journal de la 404 (pas la page d'erreur côté client, on aura juste le chemin de la requête, ça n'indiquera jamais si Apache tente de la résoudre autrement) ?

    Les règles sont correctes, il manque un élément (éventuellement générant un conflit) à moins d'un problème de cache.

  9. #9
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    581
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 581
    Points : 146
    Points
    146
    Par défaut
    Non à priori les urls à réécrire ne semblent pas de la forme /Internet/accueil.html et /Internet/actu/5.html, puisque la redirection sur l'accueil fonctionne correctement !

    Où est-ce que je peux trouver la trace dans le journal de la 404 ?

  10. #10
    Expert éminent sénior

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Points : 17 777
    Points
    17 777
    Par défaut
    Citation Envoyé par nicolas2603 Voir le message
    Non à priori les urls à réécrire ne semblent pas de la forme /Internet/accueil.html et /Internet/actu/5.html, puisque la redirection sur l'accueil fonctionne correctement !
    Il y a une incohérence alors avec :
    Citation Envoyé par nicolas2603 Voir le message
    en revanche, mes fichiers ne sont pas à la racine du localhost mais dans un dossier Internet
    Citation Envoyé par nicolas2603 Voir le message
    The requested URL /Internet/actu/5.html was not found on this server
    Chemin incorrect sur l'URL de redirection ou absence de RewriteBase ? Mais, comme je le disais, il peut très bien y avoir un défaut dans sa mise en œuvre et la réécriture de accueil.html peut parfaitement être assurée par des règles situées ailleurs (c'est possible). Parce qu'il y a visiblement un répertoire intermédiaire /Internet/ qui n'a pas été pris en compte où que ce soit (ni dans les URLs que vous avez donné initialement ni dans le chemin de la ressource vers laquelle on redirige) et qui devrait l'être (à moins que le but ne soit effectivement de rediriger l'URL http://www.monsite.fr/Internet/actu/5.html [fictive] sur http://www.monsite.fr/Internet/index.php?page=actu&id=5 [réelle] et que le .htaccess soit situé dans ce sous-répertoire /Internet/ auquel cas le raisonnement est correct sinon non). L'emplacement de chaque chose a son importance ainsi que votre configuration or il nous en manque vraisemblablement des parties et/ou avancez des choses erronées.

    Tentez de forcer la redirection (ajout du flag R), ça permettra d'éventuellement mettre en lumière s'il y a réécriture et ce sur quoi aboutit l'URL.

    Citation Envoyé par nicolas2603 Voir le message
    Où est-ce que je peux trouver la trace dans le journal de la 404 ?
    Dans le journal d'erreur. Son chemin est indiqué par la directive ErrorLog au niveau du VirtualHost concerné.

  11. #11
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    581
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 581
    Points : 146
    Points
    146
    Par défaut
    Tous mes fichiers sont dans Internet, même mon index.php. Donc logiquement c'est comme si ce dossier était la racine non ? !

    J'ai cette arborescence :
    • Internet/index.php
    • Internet/accueil.php
    • Internet/actu/actu.php
    • Internet/actu/detail/actu_5.php


    Avec ces url réelles :
    • Internet/index.php
    • Internet/index.php?page=accueil
    • Internet/index.php?page=actus
    • Internet/index.php?page=actu&id=5


    Qui sont redirigées comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $pages=array(
         'accueil'=>'accueil.php',
         'actus'=>'actu/actus.php',
         'actu'=>'actu/detail/5.php'
    );
    Et les urls fictives :
    • Internet/accueil.html <- fonctionne
    • Internet/actus.html <-fonctionne
    • Internet/actu/5.html <- ne fonctionne pas


    Le Log erreur m'indique :
    [Thu Apr 22 10:18:35 2010] [error] [client xxxxxx] File does not exist: C:/Logiciels/Wamp5/www/Internet/actu, referer: http://xxxxxx/Internet/actus.html

  12. #12
    Expert éminent sénior

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Points : 17 777
    Points
    17 777
    Par défaut
    Citation Envoyé par nicolas2603 Voir le message
    Tous mes fichiers sont dans Internet, même mon index.php. Donc logiquement c'est comme si ce dossier était la racine non ? !
    Non, vous n'aurez toujours qu'une seule racine web (pour un VH donné), je suppose que ce qui vous donne cette impression c'est le fonctionnement même de RewriteRule au sein des fichiers .htaccess puisque le module de réécriture avant de lire les règles supprime du chemin original la partie qui l'a amené jusqu'au répertoire du .htaccess (pour une request_uri /a/b/c/d.ext et un .htaccess trouvé en /a/b/, le chemin sera réduit à c/d.ext pour ses directives RewriteRule). C'est une exception, partout ailleurs le chemin exact aura besoin d'être considéré lors de tout ajout/modification (tester l'entête REQUEST_URI, pour des règles de réécriture qui sont situés dans un répertoire de plus haut niveau ou dans le fichier de configuration d'Apache, ...). Sinon vous allez réécrire au mieux, rien ; au pire, un peu tout et n'importe quoi.

    Citation Envoyé par nicolas2603 Voir le message
    Qui sont redirigées comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $pages=array(
         'accueil'=>'accueil.php',
         'actus'=>'actu/actus.php',
         'actu'=>'actu/detail/5.php'
    );
    Si j'ai bien compris, ce tableau est utilisé pour effectuer une inclusion par rapport au paramètre $_GET['page'] :
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if (isset($pages[$_GET['page']])) {
        require($pages[$_GET['page']]);
    } else ...
    ?

    Citation Envoyé par nicolas2603 Voir le message
    Le Log erreur m'indique :
    [Thu Apr 22 10:18:35 2010] [error] [client xxxxxx] File does not exist: C:/Logiciels/Wamp5/www/Internet/actu, referer: http://xxxxxx/Internet/actus.html
    Si l'erreur correspond bien et on laisse de côté la réécriture, c'est étrange parce qu'Apache ne semble pas trouver de répertoire Internet/actu/ pourtant listé plus haut. Si tel était bien le cas et que la réécriture était fonctionnelle, l'erreur ne serait que reporter à PHP au moment de l'inclusion.

    Le fichier .htaccess est bien dans le sous-répertoire Internet ? Il n'y a pas de règles de réécriture ailleurs (.htaccess au niveau du DocumentRoot (C:/Logiciels/Wamp5/www) ou dans le fichier de configuration d'Apache) ? Ni Internet ni actu (ce qui ne serait pas logique) n'est un Alias ?

Discussions similaires

  1. URL rewriting, j'y suis presque !
    Par querybase29 dans le forum Apache
    Réponses: 7
    Dernier message: 29/12/2012, 21h15
  2. [Débutant]infos ds session sans cookie ? url rewriting ?
    Par Satanas_et_diabolo dans le forum ASP
    Réponses: 8
    Dernier message: 10/10/2006, 17h13
  3. Activer l'url rewriting
    Par Otaugames dans le forum Apache
    Réponses: 2
    Dernier message: 09/03/2005, 14h58
  4. DLL et MainForm je suis perdu !
    Par rudy2 dans le forum C++Builder
    Réponses: 28
    Dernier message: 02/01/2005, 18h08
  5. Url Rewriting / htaccess
    Par bisi dans le forum Apache
    Réponses: 4
    Dernier message: 25/07/2004, 22h12

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo