Jump to content

Problème avec les accents


Limp

Recommended Posts

Bonjour,

J'ai un problème qui m'énerve. J'ai créer une page qui insère des données dans une table.

<?php
/*
---------------------------------------------------------
Module : Module principale
Auteur : Limp
---------------------------------------------------------
*/
/*
-------------------------
On appelle les librairies
-------------------------
*/
include('lib/connection.lib.php');

if ($_POST['boutonok'] == "OK")
{
$nom = htmlspecialchars(htmlentities($_POST['mesnompre'], ENT_QUOTES));
$profession = htmlspecialchars(htmlentities($_POST['mesprofession'], ENT_QUOTES));
$mail = htmlspecialchars(htmlentities($_POST['mesemail'], ENT_QUOTES));
$tel = htmlspecialchars(htmlentities($_POST['mestel'], ENT_QUOTES));
$titre = htmlspecialchars(htmlentities($_POST['mestitre'], ENT_QUOTES));
$message = htmlspecialchars(htmlentities($_POST['mesmessage'], ENT_QUOTES));
$ip = $REMOTE_ADDR;
$navigateur = $HTTP_USER_AGENT;
$ref = $HTTP_REFERER;
$destinataire='t*çç&%%&ç%';
$titres="Nouvelle question dans la base de donnée";
$messages="Vous avez un nouveau message dans la base de donnée!";
$sql = "INSERT INTO `message_site` (`mesnum`, `mesnompre`, `mesprofession`, `mesemail`, `mestel`, `mestitre`, `mesmessage`, `mesip`, `mesnav`, `mesref`) VALUES ('','$nom','$profession','$mail','$tel','$titre','$message','$ip','$navigateur','$ref')";
mysql_query($sql) or die('erreur d\'insertion');
echo "<div align='center'>";
echo "<font face='verdana' size='3'>Le message a bien été envoyé!</font>";
echo "</div>";
mail($destinataire,$titres,$messages,"From: Hellokeys");
mysql_close();
}
else
{
?>
<form method="post" action="?contact">
<table width="100%" border="0" cellspacing="0" cellpadding="0">
<tr>
<td width="25%"><label for="nom">Nom:</label></td>
<td width="75%"><input id="nom" name="mesnompre" type="text" size="50" /></td>
</tr>
<tr>
<td width="25%"><label for="profession">Profession:</label></td>
<td width="75%"><input id="profession" name="mesprofession" type="text" size="30" /></td>
</tr>
<tr>
<td width="25%"><label for="mail">E-mail:</label></td>
<td width="75%"><input id="mail" name="mesemail" type="text" size="50" /></td>
</tr>
<tr>
<td width="25%"><label for="tel">Téléphone:</label></td>
<td width="75%"><input id="tel" name="mestel" type="text" size="15" /></td>
</tr>
<tr>
<td width="25%"><label for="titre">Titre:</label></td>
<td width="75%"><input id="titre" name="mestitre" type="text" size="15" /></td>
</tr>
<tr>
<td width="25%"><p align="right"><label for="message">Message:</label></td>
<td width="75%"><textarea name="mesmessage" alt="message" rows="10" cols="30"><?php echo trim(htmlentities($Message)) ?></textarea></td>
</tr>
</table>
<input type="submit" name="boutonok" value="OK"> 
<input type="reset" name="vider">
</form>
<?
}
?>

Tout ce code fonctionne. Les infos sont stockés dans ma base. En revanche si une personne mets un accents dans son message ça ressemblera à ça:

Je suis &Atilde;&nbsp; gen&Atilde;&amp

Et lorsque je demande à mon code d'afficher le contenu de la table:

Je suis à genève!?

Voici le code qui s'occupe de l'affichage:

<?
/*
---------------------------------------------------------
Module : Module message base de donnée
Auteur : Limp
---------------------------------------------------------
*/
/*
-------------------------
On appelle les librairies
-------------------------
*/
include('lib/connection.lib.php');

$sql = "SELECT * FROM `message_site`";
$sql_results = mysql_query($sql) or die(mysql_error());
While($messdata = mysql_fetch_assoc($sql_results))
{
?> 
<div id="tableau1">
Numéro:<? echo(html_entity_decode($messdata['mesnum'], ENT_QUOTES)); ?><br />
Nom : <? echo(html_entity_decode($messdata['mesnompre'], ENT_QUOTES)); ?><br />
Profession:<? echo(html_entity_decode($messdata['mesprofession'], ENT_QUOTES)); ?><br />
E-mail :<? echo(html_entity_decode($messdata['mesemail'], ENT_QUOTES)); ?><br />
Téléphone :<? echo(html_entity_decode($messdata['mestel'], ENT_QUOTES)); ?><br />
Titre :<? echo(html_entity_decode($messdata['mestitre'], ENT_QUOTES)); ?><br />
Message :<? echo(html_entity_decode($messdata['mesmessage'], ENT_QUOTES)); ?><br />
Ip :<? echo(html_entity_decode($messdata['mesip'], ENT_QUOTES)); ?><br />
Navigateur :<? echo(html_entity_decode($messdata['mesnav'], ENT_QUOTES)); ?><br />
Referer :<? echo(html_entity_decode($messdata['mesref'], ENT_QUOTES)); ?><br />
</div><br />
<?
}
mysql_close();
?>

Est-ce que quelqu'un saurait comment faire???

Merci!

Link to comment
Share on other sites

Normalement tu n'as pas besoin de decoder ces entités (html_entities_decode) car en les insérant dans une page les navigateurs l'affichent correctement.

Le bug, a mon avis, vient du fait que ton PHP n'est pas configuré pour le meme codage de caracteres que le codage défini dans ta page. Donc la solution c'est soit d'enlever ces html_entities_decode, soit de donner une option a PHP pour qu'il fasse de l'unicode (UTF-8 ) ou du ISO-8859-1 (ou -15 pour avoir le caractèrere €).

Link to comment
Share on other sites

Archived

This topic is now archived and is closed to further replies.

×
×
  • Create New...