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

Langage PHP Discussion :

UTF-8 et les accents


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 277
    Points : 120
    Points
    120
    Par défaut UTF-8 et les accents
    Bonjour,

    Je suis en html5 je déclare mon charset dans ma page
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <meta charset="utf-8">
    et également dans le htaccess
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AddDefaultCharset UTF-8
    Pour la base je déclare utf-8 dans ma fonction connect
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
      function connect() {
        global $ac_mysql_host,$ac_mysql_user,$ac_mysql_password,$ac_mysql_db;
        $this->link = mysql_connect($ac_mysql_host,$ac_mysql_user,$ac_mysql_password);
          mysql_query("SET NAMES 'utf8'");
                mysql_query("SET CHARACTER SET utf8");
                mysql_query("SET COLLATION_CONNECTION = 'utf8_unicode_ci'");
        if($this->link) {
          if(mysql_select_db($ac_mysql_db)) {
            $this->connected = true;
            return true;
          } else {        return false;
          }
        } else {
          return false;    
        }
      }
    Ma page est donc en utf-8 et les accents qui ne viennent pas de ma base s'affichent correctement.

    Tout ce qui vient de ma base déforme les accents en ?
    (les accents dans ma base sont en latin comme é et non pas &eacute; )

    J'ai essayé de changer l'interclassement de la table et des champs de latin en utf et vise versa mais rien à faire les accents restent déformés...

    Je suis obligé de mettre dans ma page
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_query("set names 'utf8'");
    Mais cette solution est plus une rustine qu'on codage sérieux car set names 'utf8' se trouve déja dans ma fonction connect !

    Ou puis je avoir un latin qui se balade pour que mes accents soit déformées en sortant de ma base ?

    Merci

  2. #2
    Membre émérite
    Avatar de Kaamo
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    1 165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 165
    Points : 2 778
    Points
    2 778
    Par défaut
    Apache, PHP et mySQL : Passez à l'UTF-8 sans manquer une étape

    - Le point "II. Au niveau du document HTML" => utilise ta syntaxe vu que tu fais de HTML5.
    - Le point III => a vérifier de ton coté. Tu ne mentionnes pas ta façon de coder tes pages
    - Le point IV semble respecté
    - Je pense que tu bloques au niveau du point V

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 277
    Points : 120
    Points
    120
    Par défaut
    merci pour cette réponse, effectivement c'est peut être ma fonction qui ne fonctionne pas si je suis obligé de déclarer set names utf dans ma page.

    Est ce que tu vois une bêtise dans cette fonction ?

  4. #4
    Membre émérite
    Avatar de Kaamo
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    1 165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 165
    Points : 2 778
    Points
    2 778
    Par défaut
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    mysql_query("SET NAMES 'utf8'");
    mysql_query("SET CHARACTER SET utf8");
    mysql_query("SET COLLATION_CONNECTION = 'utf8_unicode_ci'");
    Tu es sous quelle version de PHP ? Si PHP 5, utilise mysql_set_charset( 'utf8' );
    Sinon, mysql_query("SET NAMES 'utf8'"); suffira.

    Cela permet de positionner la "méthode de langage" entre PHP et MySQL. MAIS, il faut que les données stockées dans tes tables soient également en UTF8, sinon ça ne marchera pas.
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER TABLE `ma_table` CHANGE `mon_champ` `mon_champ` VARCHAR( 50 ) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL;

  5. #5
    Membre éprouvé Avatar de tdutrion
    Homme Profil pro
    Architecte technique
    Inscrit en
    Février 2009
    Messages
    561
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2009
    Messages : 561
    Points : 1 105
    Points
    1 105
    Par défaut
    Il est assez déconseillé d'utiliser mysql_*, il vaudrait mieux utiliser PDO... Ceci dit ça ne changera rien au problème d'utf8.

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 277
    Points : 120
    Points
    120
    Par défaut
    Bonjour,

    Merci tout est ok maintenant

  7. #7
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Je précise cependant que la Collation mysql n'est pas l'encodage des données mais la façon dont elles sont triées et comparées.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  8. #8
    Expert éminent sénior

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 380
    Points : 10 410
    Points
    10 410
    Par défaut
    Citation Envoyé par Théocrite Voir le message
    Il est assez déconseillé d'utiliser mysql_*, il vaudrait mieux utiliser PDO...
    ... ou mysqli, ce qui permet de mettre du code à jour avec peu de modifications...

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [MySQL] Les accents - Utf-8 ?
    Par Leguman31000 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 26/02/2015, 11h01
  2. Encodage UTF-8 enlève les accents d'un String
    Par Marc_27 dans le forum Langage
    Réponses: 11
    Dernier message: 06/11/2014, 17h48
  3. [1.x] Problème avec les accents - UTF-8
    Par Laurent001 dans le forum Débuter
    Réponses: 11
    Dernier message: 07/10/2011, 20h33
  4. HTML encode UTF-8 et les accents
    Par Spir dans le forum Langage
    Réponses: 7
    Dernier message: 28/12/2008, 21h03
  5. Comment afficher les accent sous mysql v4.0.13
    Par buildozer dans le forum Requêtes
    Réponses: 2
    Dernier message: 17/06/2003, 09h33

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