$string = file_get_contents(\'http://example.com\');
if (\'UTF-8\' === mb_detect_encoding($string)) {
$dom = new DOMDocument();
// hack to preserve UTF-8 ch
In case it is definitely the DOM screwing up the encoding, this trick did it for me a while back the other way round (accepting ISO-8859-1 data). DOMDocument should be UTF-8 by default in any case but you can still try:
$dom = new DOMDocument('1.0', 'utf-8');
I had to add a utf8 header to get the correct view:
header('Content-Type: text/html; charset=utf-8');
At the top of the script where your php code lies(the code you posted here), make sure you send a utf-8 header. I bet your encoding is a some variant of latin1 right now. Yes, I know the remote webpage is utf8, but this php script isn't.
I had similar problems recently, and eventually found this workaround - convert all the non-ascii characters to html entities before loading the html
$string = mb_convert_encoding($string, 'HTML-ENTITIES', "UTF-8");
$dom->loadHTML($string);