Je développe actuellement un site Web en Php. Il devra accéder à des informations enregistrées dans une base de données et les afficher sur la page.
La base, les tables et les champs sont encodés en UTF8. La page doit également s'afficher en UTF8.
Les informations ont été enregistrées via Phpmyadmin (en UTF8).
A priori, le texte devrait s'afficher correctement dans la page en UTF8. Le problème, c'est qu'il est en ISO-8859-1, malgré tous les paramètres configurés en UTF8.
En faisant une recherche sur Google, j'ai appris que je devais utiliser SET NAMES utf8. Effectivement, cela a réglé le problème. Toutefois, j'aimerais comprendre pourquoi tous les autres réglages n'ont eu aucun effet.
En fait, dans la page (en xHtml), j'ai inséré : « <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
». Peu importe le navigateur, la page doit s'afficher en UTF8.
Le problème ne vient pas du navigateur, mais de MySQL. Même si j'ai indiqué, dans la base de données, que les informations enregistrées étaient en UTF8, elles sont renvoyées en ISO-8859-1.
PS : Lors de leur enregistrement via Phpmyadmin, mon navigateur était bien en UTF8.
En fait, dans la page (en xHtml), j'ai inséré : « <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
». Peu importe le navigateur, la page doit s'afficher en UTF8.
Le problème ne vient pas du navigateur, mais de MySQL. Même si j'ai indiqué, dans la base de données, que les informations enregistrées étaient en UTF8, elles sont renvoyées en ISO-8859-1.
PS : Lors de leur enregistrement via Phpmyadmin, mon navigateur était bien en UTF8.