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 :

[PHP-JS] Décodage de caractères


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    99
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 99
    Points : 46
    Points
    46
    Par défaut [PHP-JS] Décodage de caractères
    Bonjour à tous,
    J'ai un gros problème de décodage de caractères, je m'explique, j'ai un forum phpBB à partir duquel j'ai fais un petit script php pour récupérer les messages les plus récents. Pour ceux que ça intéresse voici le script:
    $connect = mysql_connect($serveur, $pseudo, $pass);
    $db = mysql_select_db($base);

    $sql = "SELECT `topic_id`, `topic_title`, `topic_time`, `forum_name`, phpbb_forums.forum_id
    FROM `phpbb_topics`, `phpbb_forums`
    WHERE phpbb_forums.forum_id = phpbb_topics.forum_id
    AND `auth_view` = '0'
    ORDER BY `topic_time` DESC
    LIMIT 0,6";
    $r_topics = mysql_query($sql) or die(mysql_error());
    while ($aff_forums = mysql_fetch_array($r_topics))
    {
    $id = $aff_forums['topic_id'];
    $f_id = $aff_forums['forum_id'];
    $title = $aff_forums['topic_title'];
    $f_title = $aff_forums['forum_name'];
    $time = $aff_forums['topic_time'];
    $time = date("d-m-Y", $time);

    //Comparaison de la date courante avec la date du post
    //On récupère la date courante
    $current_time = date("d-m-Y");
    //On récupère la date courante sous forme d'un timestamp
    $explodetoday = explode("-", $current_time);
    $stoday = mktime(0, 0, 0, $explodetoday[1], $explodetoday[0], $explodetoday[2]);

    //On récupère la date du post sous forme d'un timestamp
    $explodepastdate = explode("-", $time);
    $spastdate = mktime(0, 0, 0, $explodepastdate[1], $explodepastdate[0], $explodepastdate[2]);

    //On récupère la différence en jours
    $difference = $stoday - $spastdate;
    $days = intval($difference/86400);

    //Si la différence est inférieure à 5 jours, on considère comme une nouveauté
    if($days < 5)
    $new_post = '&nbsp;<img src="new.gif" width="30" height="13" alt="nouveaut&eacute;" /><br />';
    else
    $new_post = "<br />";

    $post = mysql_db_query($base,"select `post_id`, `poster_id` from phpbb_posts where topic_id = '$id'" ,$connect);
    $p = mysql_fetch_array($post);
    $p_id = $p['post_id'];

    //utilisateur à avoir écris sur le post
    $user_id = $p['poster_id'];

    $requete_utilisateur = mysql_db_query($base,"select `username` from phpbb_users where user_id = '$user_id'" ,$connect);
    $u = mysql_fetch_array($requete_utilisateur);
    $name = $u['username'];

    echo "<font color=\"#018AB9\">".$time." - <strong>".html_entity_decode($name)." : </strong></font><a href=\"http://forum.cvk.fr/viewtopic.php?t=".$id."\">".html_entity_decode($title)."</a>".$new_post;
    }
    mysql_close($connect);
    Le problème auquel je suis confronté est qu'il n'affiche pas correctement les caractères accentués ou les doubles cotes.

    Pour voir le résultat, voici le lien de mon site sur lequel vous verrez en bas de la page d'accueil le problème que j'évoque.
    www.cvk.fr

    Est ce un problème dans mon script? Dans l'encodage de ma BDD? Dans le décodage de ma page?

    Merci de votre aide,
    Alex

  2. #2
    Membre émérite
    Avatar de yiannis
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    1 494
    Détails du profil
    Informations personnelles :
    Âge : 59
    Localisation : France

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 494
    Points : 2 791
    Points
    2 791
    Par défaut
    Bonjour,

    essaies de mettre un charset- UTF-8 sur ta page pour voir si cela corrige ton probleme

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    99
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 99
    Points : 46
    Points
    46
    Par défaut
    Citation Envoyé par yiannis
    Bonjour,

    essaies de mettre un charset- UTF-8 sur ta page pour voir si cela corrige ton probleme

    Ca n'a pas l'air de changer
    j'ai mis:
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

  4. #4
    Membre émérite
    Avatar de yiannis
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    1 494
    Détails du profil
    Informations personnelles :
    Âge : 59
    Localisation : France

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 494
    Points : 2 791
    Points
    2 791
    Par défaut
    ok, c'est que le charset doit etre en ISO-8859-1

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    99
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 99
    Points : 46
    Points
    46
    Par défaut
    Citation Envoyé par yiannis
    ok, c'est que le charset doit etre en ISO-8859-1
    En effet, tu as raison... J'ai rajouté ça das mon script:

    htmlentities($name, ENT_QUOTES, 'ISO-8859-1')
    Là tout s'affiche bien!! Sauf les " qui reste en &quot;. Comment faire pour régler ce dernier bug?

    Par contre, ce que je ne comprends pas c'est que dans PhpMyAdmin mes BDD sont encodé en UTF-8 donc pourquoi sur ma page HTML je dois mettre du ISO?

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    99
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 99
    Points : 46
    Points
    46
    Par défaut
    Je n'arrive pas à enlever les &quot;. Comment faire pour régler ce dernier bug?

Discussions similaires

  1. [PHP-JS] Encodage des caractères
    Par 123quatre dans le forum Langage
    Réponses: 4
    Dernier message: 14/11/2007, 16h14
  2. PHP/MySQL stocker le caractère €
    Par mguinot dans le forum Requêtes
    Réponses: 1
    Dernier message: 30/05/2006, 16h52
  3. [PHP-JS] Interdire un caractère en PHP
    Par Rekiem dans le forum Langage
    Réponses: 6
    Dernier message: 13/04/2006, 22h13
  4. [SQL-Server] ms sql server et php : problème avec les caractères accentués
    Par stephane9422 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 05/12/2005, 17h45
  5. [Réseau]Problème de décodage de caractère
    Par addack dans le forum Entrée/Sortie
    Réponses: 7
    Dernier message: 01/12/2005, 11h09

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