Limp Posted October 4, 2005 Share Posted October 4, 2005 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 à genÃ& 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 More sharing options...
njoyard Posted October 4, 2005 Share Posted October 4, 2005 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 More sharing options...
Limp Posted October 4, 2005 Author Share Posted October 4, 2005 J'ai enlevé le HTML_ENTITY mais c'est toujours pas ça... M'énerve! Ce que je capte pas c'est que ça fonctionnne très bien avec un autre site... Link to comment Share on other sites More sharing options...
Limp Posted October 4, 2005 Author Share Posted October 4, 2005 J'ai réussi!!! Message :<? echo(html_entity_decode(utf8_decode($messdata['mesmessage']), ENT_QUOTES)); ?><br /> Ouf! Link to comment Share on other sites More sharing options...
Recommended Posts
Archived
This topic is now archived and is closed to further replies.