Ressources gratuites pour aider les débutants à créer, gérer et développer leur site Joomla

Joomla et fichier htaccess

Les fichiers htaccess sont des fichiers de configuration destinés aux serveurs Apache. Ce fichier, installé dans un dossier transmet des informations, des régles, des restrictions concernant ce répertoire et son contenu.

Les fichiers .htaccess (ou "fichiers de configuration distribués") fournissent une méthode pour modifier la configuration du serveur au niveau d'un répertoire. Un fichier, contenant une ou plusieurs directives de configuration, est placé dans un répertoire de documents particulier, et ses directives s'appliquent à ce répertoire et à tous ses sous-répertoires.

Source : https://httpd.apache.org/docs/2.4/fr/howto/htaccess.html

A quoi sert un fichier .htaccess ?

Les fichiers htaccess sont utilisés pour la sécurité :

  • Configurer les droits d'accès à un répertoire
  • Protéger le contenu d'un répertoire pa mot de pass

Et pour le référencement :

  • Configurer des redirections d'URL et éviter les erreurs 404
  • Réécrire les URL pour les simplifier
  • ...

Emplacement

L'emplacement de ce type de fichier est particulier. Le fichier est installé dans un répertoire de données et agit sur ce répertoire et sur tous les sous-répertoires que ce dernier peut contenir. On peut placer d'autres fichiers .htaccess dans les sous répertoires. Quand le fichier .htaccess est placé dans un répertoire, il est détecté et exécuté par le serveur Apache.

Joomla et htaccess

Les sites Joomla sont protégés par un fichier .htaccess placé à la racine du site mais les répertoires contenant les templates en contiennent un aussi. A la racine des fichiers Joomla se trouve déjà un fichier htaccess.txt. Il faut tout simplement renommer le fichier directement en .htaccess, dans le client FTP. L'opération est simple à effectuer : dans Filezilla, il faut se connecter au serveur du site, puis à la racine du site Joomla, cliquer droit sur le fichier htaccess.txt et le renomme en .htaccess.

Le chmod de ce fichier est 444.

Les applications

Créer une redirection 301

La redirection 301 est une redirection permanente. Son principe est simple la redirection 301 redirige l'internaute vers une nouvelle URL. Par exemple on souhaite que, lorsque l'internaute saisisse dans la barre d'adresse de Google www.monsite.com qu'il aboutisse sur www.monsite.net. Les redirections 301, la plus part du temps visent à changer le nom de domaine d'un site, orienter une page vers une autre page ou gérer les différentes syntaxes d'une URL.

Avec ce type de redirection, l'utilisateur n'aboutit pas sur une page 404, le site conserve son positionnement dans Google.

Quelques redirections que l'on peut mettre en place :

Rediriger un nom de domaine vers un autre

www.monanciensiteweb.fr vers www.nouveausiteweb.fr
Solution dans le fichier .htaccess de www.monanciensiteweb.fr :

RewriteEngine on
RewriteRule (.*) http://wwwnouveausiteweb.fr/$1 [R=301,L]

Rediriger les anciennes pages vers les nouvelles

www.monsiteweb.fr/ancienne-url vers www.monsiteweb.fr/nouvelle-url 
Solution dans le fichier .htaccess :

RewriteCond %{HTTP_HOST} ^www.monsiteweb.fr/ancienne-url
RewriteRule ^(.*) http://www.monsiteweb.fr/nouvelle-url [QSA,L,R=301]

Rediriger le contenu d'un ancien dossier vers le nouveau

www.monsiteweb.fr/ancien-dossier (et toutes les pages qu'il contient) vers www.monsiteweb.fr/nouvelle-url
Solution dans le fichier .htaccess :

RedirectMatch 301 ^/ancien-dossier.* http://www.monsite.com/nouvelle-url

Sans www. vers avec www 

monsiteweb.fr vers www.monsiteweb.fr

RewriteEngine On 
RewriteCond %{HTTP_HOST} !^www\.monsiteweb\.com [NC] 
RewriteRule (.*) http://www.monsiteweb.com/$1 [QSA,R=301,L] 

Rediriger les pages index.html , index.php.... vers la racine de site 

RewriteEngine On 
RewriteCond %{THE_REQUEST} ^(GET|POST|HEAD)\ (/.*)?/index.(htm|html|php|asp|shtml)
RewriteRule ^(.*)index.(htm|html|php|asp|shtml)$ /$1 [R=301,L]

Rediriger une ancienne page vers une nouvelle

RewriteEngine On 
RewriteRule ancienpage.html http://www.monsiteweb/nouvelle-page.html [R=301] 
Sécurisation du fichier .htaccess (et configuration.php)

Ce code est à placer en début de de .htaccess en-dessous de "## Mod_rewrite in use"

RewriteEngine On
<Files .htaccess>
order allow,deny
deny from all
</Files>
<Files configuration.php>
order allow,deny
deny from all</Files>

La documentation complète Apache : 
http://httpd.apache.org/docs/2.2/mod/mod_rewrite.html#rewriteflags
https://httpd.apache.org/docs/trunk/fr/rewrite/intro.html
 

Voici un exemple de fichier htaccess

Ne pas utiliser le htaccess.txt ici car lors d'une mise à jour de Joomla, il sera remplacé et les modifications seront alors perdues.

##
# @package Joomla
# @copyright Copyright (C) 2005 - 2018 Open Source Matters. All rights reserved.
# @license GNU General Public License version 2 or later; see LICENSE.txt
##
 
##
# READ THIS COMPLETELY IF YOU CHOOSE TO USE THIS FILE!
#
# The line 'Options +FollowSymLinks' may cause problems with some server configurations.
# It is required for the use of mod_rewrite, but it may have already been set by your 
# server administrator in a way that disallows changing it in this .htaccess file.
# If using it causes your site to produce an error, comment it out (add # to the 
# beginning of the line), reload your site in your browser and test your sef urls. If 
# they work, then it has been set by your server administrator and you do not need to 
# set it here.
##
 
## No directory listings
<IfModule autoindex>
  IndexIgnore *
</IfModule>
 
## Can be commented out if causes errors, see notes above.
Options +FollowSymlinks
Options -Indexes
 
## Mod_rewrite in use.
 
RewriteEngine On
 
## Begin - Rewrite rules to block out some common exploits.
# If you experience problems on your site then comment out the operations listed 
# below by adding a # to the beginning of the line.
# This attempts to block the most common type of exploit `attempts` on Joomla!
#
# Block any script trying to base64_encode data within the URL.
RewriteCond %{QUERY_STRING} base64_encode[^(]*\([^)]*\) [OR]
# Block any script that includes a <script> tag in URL.
RewriteCond %{QUERY_STRING} (<|%3C)([^s]*s)+cript.*(>|%3E) [NC,OR]
# Block any script trying to set a PHP GLOBALS variable via URL.
RewriteCond %{QUERY_STRING} GLOBALS(=|\[|\%[0-9A-Z]{0,2}) [OR]
# Block any script trying to modify a _REQUEST variable via URL.
RewriteCond %{QUERY_STRING} _REQUEST(=|\[|\%[0-9A-Z]{0,2})
# Return 403 Forbidden header and show the content of the root home page
RewriteRule .* index.php [F]
#
## End - Rewrite rules to block out some common exploits.
 
## Begin - Custom redirects
#
# If you need to redirect some pages, or set a canonical non-www to
# www redirect (or vice versa), place that code here. Ensure those
# redirects use the correct RewriteRule syntax and the [R=301,L] flags.
#
## End - Custom redirects
 
##
# Uncomment the following line if your webserver's URL
# is not directly related to physical file paths.
# Update Your Joomla! Directory (just / for root).
##
 
# RewriteBase /
 
## Begin - Joomla! core SEF Section.
#
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
#
# If the requested path and file is not /index.php and the request
# has not already been internally rewritten to the index.php script
RewriteCond %{REQUEST_URI} !^/index\.php
# and the requested path and file doesn't directly match a physical file
RewriteCond %{REQUEST_FILENAME} !-f
# and the requested path and file doesn't directly match a physical folder
RewriteCond %{REQUEST_FILENAME} !-d
# internally rewrite the request to the index.php script
RewriteRule .* index.php [L]
#
## End - Joomla! core SEF Section.

Agence Joomla

Téléphone : 0672271069

Email : contact@sylvie-ceci.info

Lun Vend 8h00 18h00

Liens utiles