after querying a mysql db using the code below i have generated an html file:
$myFile = "page.htm";
$fh = fopen($myFile, 'w') or die("can't open file"); fwrite($fh, $row['text']); fclose($fh);
On the msql db the text is encoded using utf8_general_ci. But i need to include it in a php web page as shown below:
<?include('page.htm');?>
bearing in mind that the php web page uses utf8 charset on the header:
<meta http-equiv="content-type" content="text/html; charset=utf8" />
Now if i write on the db some letters with grave accent (è à ì) or a quote character and i open directly page.htm and on the db i see it all looking ok, but when i view it on the php page i see a question mark � character instead of those I originally wanted. Why?! Thanks in advance!
The problem is that the encoding of the html page is actually set by the http response header 'Content-Type', to fix what you need to do is add the following to your PHP file before any output (ie at the top).
To clarify, that should be in the PHP that includes your html file, not in the html file you include :)
side point(s):
The problem is probably with a wrong encoding set in your mySQL database, or the database connection.
If your tables are all 100%
utf8_general_ci
, try doing amysql_query("SET NAMES utf8;");
before doing any queries: That will set the connection to UTF-8.Try separate includes blocks. Ex mainpage.php:
META charset isn't always solve the problem. Make sure your IDE saving real UTF-8 files. For exanple in Dreamweaver press CTRL-J then check Title/Encoding options.
One point about your code:
when you use include, it is a php code, so you should include a php file, not a htm file:
try changing the extension, I don't know how your code were working till now :)
If you are getting stuff from a database, and it changes charset inexplicitly, note that in Php the actual connection charset to the db needs to be set explicitly to utf8 (if that's what you use), otherwise the content is converted while transfered, even if the content in the db itself is in correct format.. an interesting quirk ;)
Like so: mysql_select_db($database, $connect); mysql_set_charset('utf8', $connect); // set the connection charset.