《PHP編程:php解決DOM亂碼的方法示例代碼》要點:
本文介紹了PHP編程:php解決DOM亂碼的方法示例代碼,希望對您有用。如果有疑問,可以聯系我們。
PHP學習前言
PHP學習DOM是php比較新的xml和html處理類,可以像javascript那樣方便的操作DOM樹,網上更多的是介紹它處理XML的情況,今天這篇文章就介紹下php解決DOM亂碼的方法,下面話不多說,直接看下面的解決方法.
PHP學習解決方法如下
PHP學習
/**
* 請求url頁面信息
* @param str $url
* @return str mixed|boolean
*/
function curl_get($url) {
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
//302跳轉
curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($curl, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:47.0) Gecko/20100101 Firefox/47.0');
curl_setopt($curl, CURLOPT_REFERER, $url);
$data = curl_exec($curl);
$code = curl_getinfo($curl,CURLINFO_HTTP_CODE); //輸出請求狀態碼
curl_close($curl);
if(200 == $code) {
//解決亂碼
if (preg_match('#<meta[^>]*charset="?gb2312"[^>]*>#', $data)) {
$data = iconv("gb2312","utf-8//IGNORE",$data);
$data = preg_replace('#<meta[^>]*charset="?gb2312"[^>]*>#is', '<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">', $data);
}
if (!preg_match('#<meta charset="utf-8"[^>]*>#is', $data)) {
$data = str_replace('<head>', '<head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">', $data);
}
if (preg_match('#<meta charset="utf-8"[^>]*>#is', $data)) {
$data = preg_replace('#<meta charset="utf-8"[^>]*>#is', '<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">', $data);
}
return $data;
} else {
return false;
}
}
PHP學習
/**
* 獲取 DOMDocument 對象
* @param str $url
* @return boolean|DOM
*/
function getDom($url) {
$html_content = curl_get($url);
if(empty($html_content)) {
//saveLog($url, '請求失敗');
return false;
}
$dom = new DOMDocument('1.0', 'utf-8');
libxml_use_internal_errors(true);
$dom->loadHTML($html_content);
return $dom;
}
PHP學習
$html_content = mb_convert_encoding($html_content, 'UTF-8', 'gb2312');
PHP學習總結
PHP學習以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流.
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/2630.html