10 回答
You can have a mix of PHP and HTML in your PHP files... just do something like this...
<?php
$string = htmlentities("Résumé");
?>
<html>
<head></head>
<body>
<p><?= $string ?></p>
</body>
</html>
That should output Résumé
just how you want it to.
If you don't have short tags enabled, replace the <?= $string ?>
with <?php echo $string; ?>
In PHP there is a pretty good function utf8_encode() to solve this issue.
echo utf8_encode("Résumé");
//will output Résumé instead of R�sum�
So I try htmlspecialchars() or htmlentities() which outputs <p>Résumé<p> and the browser renders <p>Résumé<p>.
If you've got it working where it displays Résumé
with <p></p>
tags around it, then just don't convert the paragraph, only your string. Then the paragraph will be rendered as HTML and your string will be displayed within.
$str = "Is your name O\'vins?";
// Outputs: Is your name O'vins? echo stripslashes($str);
This works for me:
Create/edit .htaccess
file with these lines:
AddDefaultCharset UTF-8
AddCharset UTF-8 .php
If you prefer create/edit php.ini
:
default_charset = "utf-8"
Sources:
Try This
Input:
<!DOCTYPE html>
<html>
<body>
<?php
$str = "This is some <b>bold</b> text.";
echo htmlspecialchars($str);
?>
<p>Converting < and > into entities are often used to prevent browsers from using it as an HTML element. <br />This can be especially useful to prevent code from running when users have access to display input on your homepage.</p>
</body>
</html>
Output:
This is some <b>bold</b> text.
Converting < and > into entities are often used to prevent browsers from using it as an HTML element. This can be especially useful to prevent code from running when users have access to display input on your homepage.
This works for me. Try this one before the start of HTML. I hope it will also work for you.
<?php header('Content-Type: text/html; charset=iso-8859-15'); ?>
<!DOCTYPE html>
<html lang="en-US">
<head>
The following worked for me when having a similar issue lately:
$str = iconv('iso-8859-15', 'utf-8', $str);
One of the best ways to do this is, change Collation in my SQL database.
step 1: Go to the Mysql database
step 2: Select the Text-based Row you want to get displayed (Eg., post or comments)
step 3: edit the row and select collation as below.
utf8mb4_unicode_ci
Make sure to change the collation of text rows whichever you want to display the special characters.
Sometimes htmlspecialchars_decode() or any other entity() doesn't convert your special chars to normal. So, the above method will definitely help.