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

PHP & Base de données Discussion :

probleme d'accent bizarre [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2006
    Messages : 324
    Par défaut probleme d'accent bizarre
    Bonjour, j'ai un problème de paramétrage afin que les résultats des requêtes s'affiche correctement au niveau des accents entre autres (actuellement tous les caractères accentués affiche un ?) :

    Suite à différentes recherches sur les forums, ma bse Mysql est parametrée comme suit :
    Type :MyISAM
    Interclassement par defaut de la table : utf8_general_ci
    Interclassement des champs : vide ou utf8_general_ci

    Mes pages PHP ou HTML comporte toutes l'entête suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    et ça ne fonctionne toujours pas

    Si quelqu'un à une solution, je lui fais la bise

    merci

  2. #2
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    encode ta page en UTF8 (Sans DOM), tu peux le faire facilement avec Notepad++ ou encore Dreamweaver (CTRL+J)

  3. #3
    Membre émérite Avatar de obito
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2008
    Messages
    773
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2008
    Messages : 773
    Par défaut
    Pour ntotepad ++ Sélectionne tout ton code puis format->convertir en utf8

    Le but étant d'éviter les fonction php tel que utf8_encode ou utf8_decode qui ne rends pas le code très propre =)

  4. #4
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    Citation Envoyé par obito Voir le message
    Pour ntotepad ++ Sélectionne tout ton code puis format->convertir en utf8

    Le but étant d'éviter les fonction php tel que utf8_encode ou utf8_decode qui ne rends pas le code très propre =)
    C'est tout à fait ça

    Et j'en profite pour corrigé mon erreur du post plus haut, il s'agit bien sur d'UTF-8 (sans BOM) et non pas "sans DOM" ! honte sur moi, j'irai me faire flagellé sur la place du marché

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2006
    Messages : 324
    Par défaut
    avec Dreamweaver je choisis
    type de document (DTD) : HTML 4.01 strict ??

  6. #6
    Membre émérite Avatar de obito
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2008
    Messages
    773
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2008
    Messages : 773
    Par défaut
    Non

    Pour Dreamweaver:

    Aller dans modifier->propriété de la page->Titre/Codage

  7. #7
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    Citation Envoyé par nicolasferraris Voir le message
    avec Dreamweaver je choisis
    type de document (DTD) : HTML 4.01 strict ??
    non ça n'a rien à voir ça ^^ ca c'est pour l'HTML

    CTRJ+J => Titre/Codage => Codage => UTF-8

  8. #8
    Membre émérite Avatar de obito
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2008
    Messages
    773
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2008
    Messages : 773
    Par défaut
    Citation Envoyé par darkstar123456 Voir le message
    non ça n'a rien à voir ça ^^ ca c'est pour l'HTML

    CTRJ+J => Titre/Codage => Codage => UTF-8
    Y en a qui connaisses les raccourcis ^^ Moi je l'utilise jamais merci pour l'astuce =)

  9. #9
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2006
    Messages : 324
    Par défaut
    Voila avec Dreamweaver j'ai modifié les propriétés des pages avec dans la rubrique Titre/codage :
    Type de document : XHML 1.0 Transitional
    Codage : unicode (utf-8)
    Formulaire de normalisation unicode : c(décomposition canonique suivie d'une composition canonique)

    avec la se "inclure une signature unicode BOM" decochée

    je me retrouve donc avec l'entête suivant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
     
    <html xmlns="http://www.w3.org/1999/xhtml"><head>
    sur tous mes fichiers, mais ça ne marche toujours pas

  10. #10
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2006
    Messages : 324
    Par défaut
    Si je remplace un "é" par un "&eacute;" dans la base MySql c'est Ok mais bon...

  11. #11
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2006
    Messages : 324
    Par défaut
    Si j'utilise "utf8_encode" pour afficher mes champ au niveau de la page PHP, ça marche aussi....mais bon

  12. #12
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    c'est dans ta base alors que ça déconne... surement au moment de l'insert dans la DB (vérifie la page du formulaire qui gère l'INSERT [ainsi que celle du formulaire si ce sont 2 pages séparées])

  13. #13
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2006
    Messages : 324
    Par défaut
    Excuses moi mais j'ai pas tout compris, j'ai pas 'INSERT ni de formulaire

    j'ai une page PHP qui récupère des données déja entrées dans une base

    Voici le code tronqué de ma page PHP

    Code : 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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml"><head>
    </head><head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Document sans titre</title>
    </head>
    <body>
    <?php
    $host = '';
    $user = '';
    $pass = '';
    $db = 'mabase';
     
    $link = mysql_connect ($host,$user,$pass) or die ('Erreur : '.mysql_error() );
    mysql_select_db($db) or die ('Erreur :'.mysql_error());
     
    $result = mysql_query("SELECT * FROM matable ORDER BY $cletri1 $ordretri1 LIMIT $start, $nb_results_p_page")or die ('Erreur : '.mysql_error() );
     
    // lecture et affichage des résultats   
        	while($row = mysql_fetch_array($result)) {
     	    echo '<table>'."\n";
     		echo '<tr>';
     
    		echo '<td class="coltableau1"><a href="index2.php?id='.$row['titre'] .'"class="liencoltableau1">'.$row['titre'].'</a></td>';
    		 echo '</tr>';
     
    		echo '</table>'."\n";
     
     
    ?>
     
     
    </body>
    </html>

  14. #14
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    et bien c'est simple, il suffit de raisonner... si un utf8_encode() permet d'afficher correctement tes caractères, c'est que ces derniers ne sont pas en UTF8 dans ta DB.

    (je pensais donc que ca devait être le formulaire d'ajout mais vu que tu n'en as pas, regarde du côté de là où tu as ajouté tes données.... exemple : PHPMyAdmin est-il bien en UTF8 lors de l'ajout d'une ligne dans la DB ? (dans Firefox : Affichage > Encodage des caractères)

  15. #15
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2006
    Messages : 324
    Par défaut
    Lorsque je fais "dans Firefox : Affichage > Encodage des caractères" sur ma page de résultat, je suis bien UFT-8

    Quand à ma base, elle etait au préalable en "Latin swedish" et j'ai tout mis en UFT-8 mais après avoir entrée les données

    Type :MyISAM
    Interclassement par defaut de la table : utf8_general_ci
    Interclassement des champs : vide ou utf8_general_ci

    Dois-je essayer de rentrer une nouvelli ligne de données pour voir ce que cela donne

  16. #16
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    si t'as mis en UTF8 apres c'est trop tard, faut modifier tes contenus...

  17. #17
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2006
    Messages : 324
    Par défaut
    je viens d'entrer une nouvelle ligne avec PHPAdmin avec des "ààééééèè"
    mais ça ne change rien !

    Faut t'il détruire la base et en refaire une ?!!!!

  18. #18
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    renseigne toi sur la commande ALTER TABLE de mysql et CHARACTER SET, ça pourra p-e t'aider (mais c'est vrai qu'en général, on le décide AVANT si on utilise de l'UTF8 ou de l'ISO...)

  19. #19
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2006
    Messages : 324
    Par défaut
    j'ai sauvegarder l'ancienne table et j'en recrée une en UFT-8 j'ai rentrée de nouvelles données................................toujours le même problème

  20. #20
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    ton fichier de sauvegarde n'était surement pas en UTF8 ...

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. [MySQL 4.1] probleme d'accents sur une requete SQL
    Par tatayoyo dans le forum Langage SQL
    Réponses: 4
    Dernier message: 10/11/2005, 17h06
  2. Problème d'accents
    Par devmat dans le forum Gnome
    Réponses: 7
    Dernier message: 09/05/2005, 18h43
  3. probleme d'accents!!!
    Par w.b. dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 21/02/2005, 15h51
  4. probleme d'accent
    Par ericmart dans le forum Flash
    Réponses: 3
    Dernier message: 26/02/2004, 10h23
  5. probleme d'accents
    Par otb82 dans le forum Requêtes
    Réponses: 5
    Dernier message: 23/10/2003, 13h03

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