===== Convertir un site en UTF-8 =====
1/- Si on a la possibilité d’avoir accès au fichier de configuration Apache httpd.conf, rajouter en fin de fichier :\\
''AddDefaultCharset UTF-8''\\
//(S’il existe une ligne ''AddDefaultCharset ISO-8859-1'', la commenter)//\\
Ce réglage permettra à Apache d’envoyer les entêtes avec l’encodage UTF-8 pour les fichiers PHP et les fichiers HTML.
2/- Si on a pas accès à ce fichier, modifier le fichier de configuration php.ini en décommentant la ligne :\\
''default_charset="utf-8"''\\
Rajouter dans chaque fichier HTML le type d’encodage :\\
''''
3/- Si on a pas accès au fichier de configuration php.ini, créer ou modifier le fichier .htaccess, situé à la racine du projet, afin d’y insérer une instruction :\\
''php_flag default_charset utf-8''\\
Rajouter dans chaque fichier HTML le type d’encodage :\\
''''
4/- Enfin, ultime solution si les 3 précédentes ont échouées, configurer l’entête de chaque page :\\
PHP : ''header ('Content-type:text/html; charset=utf-8');''\\
HTML : ''''
//ATTENTION à n’utiliser qu’une seule des 4 solutions ci-dessus car elles se substituent les unes aux autres avec certaines priorités. Il devient donc ensuite difficile de savoir laquelle impose l’encodage.//
Encoder les fichiers PHP existant :\\
Placer le fichier "utf8.php" (ci-joint) dans chaque dossier contenant des fichier PHP à convertir et l’exécuter depuis le navigateur.
Encoder les fichiers HTML :\\
Ouvrir chaque fichier dans un éditeur du type Notepad++ et le convertir en "UTF-8 (sans BOM)".
Encoder le base de données :\\
Sur chaque table exécuter la commande suivante :\\
''ALTER TABLE `ma_table` CONVERT TO CHARACTER SET utf8''
Spécifier l’encodage dans lequel sont encodées les données envoyées via une requête :\\
Rajouter juste après le "mysql_connect" la commande :\\
''mysql_set_charset ('UTF8');''
Si on utilise PDO, il suffit de passer un quatrième argument à son constructeur comme ceci :\\
$db = new PDO ('mysql:host=localhost;dbname=tests', 'root', '', array (PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES \'UTF8\''));
Voici une astuce qui m’a permis de convertir une base SPIP complète en une seule fois. Seule contrainte, passer la commande de conversion sur un Linux :\\
1/- Faire un dump de la base complète soit avec PhpMyAdmin soit par la ligne de commande suivante\\
mysqldump -u info -p --quote-names --set-charset --default-character-set=latin1 spip > monDossier/spip-latin1.sql
2/- Dans un terminal Linux convertir la BDD par la ligne de commande suivante\\
cat monDossier/spip-latin1.sql |sed -e 's/latin1/utf8/g' > monDossier/spip-utf8.sql
3/- Réintégrer la base convertie avec PhpMyAdmin où par la ligne de commande suivante\\
mysql -u info -p spip < monDossier/spip-utf8.sql
Document joint : {{:tic:utf8.php.zip|utf8.php}}