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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 277
    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 Expert
    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 : 38
    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
    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 éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 277
    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 Expert
    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 : 38
    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
    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 émérite Avatar de tdutrion
    Homme Profil pro
    Architecte technique
    Inscrit en
    Février 2009
    Messages
    561
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    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
    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 éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

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

    Merci tout est ok maintenant

  7. #7
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 418
    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 418
    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