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 :

Comment gérer le Multilinguisme avec Mysql-PHP ?


Sujet :

PHP & Base de données

  1. #1
    Membre régulier Avatar de tavarlindar
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    262
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 262
    Points : 97
    Points
    97
    Par défaut Comment gérer le Multilinguisme avec Mysql-PHP ?
    Bonjour à tous,

    Je suis bien conscient que ce sujet à été mainte fois abordé, mais, en dépit de nombreuses recherches, je n’ai pas trouvé de réponses claires et surtout « universelle ».

    Le besoin est simple :
    que faire sur une page php pour enregistrer des données (issues de langues diverses) dans Mysql ?
    que faire pour réafficher ces données dans une page php ?

    Avant je faisais ceci dans mes formulaires :
    En très bref et très simplifié :
    Début de page dans le
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" >
        <head>
        <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
    </head>
    Un champ texte de formulaire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type='text' name='prenom’ size='10' value=" ">
    Une fois récupéré les données dans un $_POST , pour enregistrer dans mysql (interclassement par utf8_general_ci)

    Avant d’insérer ou d’updater , un petit retraitement type :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $prenom=mysql_real_escape_string($_POST['prenom’]);
    Et côté réaffichage du même champ, avec htmlspecialchars().

    Pour le français et l’anglais, pas de gros soucis. Je passe les histoires de quote et double quote.

    Maintenant si on met du russe ou du chinois … c’est une autre histoire !

    Avant d’utiliser les codes de mise à jour de base, j’ai essayé de mettre le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_query("SET character_set_results = 'utf8', character_set_client = 'utf8', character_set_connection = 'utf8', character_set_database = 'utf8', character_set_server = 'utf8'", $connexion);
    j’ai modifié aussi l’entête des pages :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    Super à priori. Les datas semblent correctement sauvegardées.
    Le gros soucis c’est pour réafficher les données, sans compter que ce qui fonctionné en français avant, ne fonctionne plus. Tous les caractères accentués sont modifiés …
    Avez-vous une solution « universelle » sans passer par du XML ?

    A la limite, que les données soit enregistrées dans la base Mysql en Hiéroglyphe illisible, je m'en fou. Ce que je souhaite c'est pouvoir enregistrer les datas comme l'utilisateur les a saisies et pourvoir ensuite les réafficher à l'identique.

    Est-ce si compliqué à l'heure de la mondialisation ?

    Par avance un immense merci à ceux qui pourront m'éclairer sur le sujet.

    tavar

  2. #2
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 692
    Points : 20 244
    Points
    20 244
    Par défaut
    Tous les caractères accentués sont modifiés
    C'est que tu n'es pas complètement en utf8.

    En se basant sur une table , un fichier php et un fichier html de vue :

    Base de données : interclassement en utf8_*.
    Fichier php : Fichier lui même encoder en utf8 (voir avec ton éditeur pour celà), Eventuellement une requete
    SET CHARACTER SET utf8 en début de page.
    Html : Meta charset utf8, fichier encodé en utf8.

    Avec ça il n'y a en principe aucun problème pour afficher des langues un peu exotique.

  3. #3
    Membre régulier Avatar de tavarlindar
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    262
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 262
    Points : 97
    Points
    97
    Par défaut
    Bonjour grunk,

    Tout d'abord merci pour ta réponse. Je vais tester avec
    "Meta charset utf8".

    Par contre, lorsque je réaffiche mes données en chinois ou russe, j'ai une succession de point d'intérogation. ??? ???? ??? etc.

    Je doute qu'un simple Meta charset utf8 change quelque chose. Il faut peut être rajouter un paramètre dans la requête sql avant ?

  4. #4
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 692
    Points : 20 244
    Points
    20 244
    Par défaut
    Quand je parle de meta charset utf8 , c'est ce que tu as utilisé c'est à dire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    Dès que tu passes en utf8 faut vraiment que toutes la chaine le soit sinon ca pose problème forcément à un moment.
    Ensuite les fonction php utf8_encode et utf8_decode peuvent te dépanner dans des cas particuliers

Discussions similaires

  1. comment gérer des fichiers avec php
    Par achraf.b.a dans le forum Langage
    Réponses: 2
    Dernier message: 12/05/2012, 09h37
  2. Réponses: 2
    Dernier message: 15/12/2009, 13h29
  3. [MySQL] conseils pour gérer des images avec mysql
    Par briiice dans le forum Administration
    Réponses: 9
    Dernier message: 04/01/2006, 10h52
  4. Comment gérer le grec dans MySQL ?
    Par LadyArwen dans le forum Requêtes
    Réponses: 14
    Dernier message: 27/01/2005, 10h24
  5. Réponses: 5
    Dernier message: 29/10/2004, 17h20

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