PHP DOM乱码怎么办,解决方法是什么
导读:这篇文章给大家分享的是“PHP DOM乱码怎么办,解决方法是什么”,文中的讲解内容简单清晰,对大家认识和了解都有一定的帮助,对此感兴趣的朋友,接下来就跟随小编一起了解一下“PHP DOM乱码怎么办,解决方法是什么”吧。...
这篇文章给大家分享的是“PHP DOM乱码怎么办,解决方法是什么”,文中的讲解内容简单清晰,对大家认识和了解都有一定的帮助,对此感兴趣的朋友,接下来就跟随小编一起了解一下“PHP DOM乱码怎么办,解决方法是什么”吧。
前言
DOM是php比较新的xml和html处理类,可以像javascript那样方便的操作DOM树,网上更多的是介绍它处理XML的情况,今天这篇文章就介绍下php解决DOM乱码的方法,下面话不多说,直接看下面的解决方法。
解决方法如下
/**
* 请求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('#]*charset="?gb2312"[^>
]*>
#', $data)) {
$data = iconv("gb2312","utf-8//IGNORE",$data);
$data = preg_replace('#]*charset="?gb2312"[^>
]*>
#is', '', $data);
}
if (!preg_match('#]*>
#is', $data)) {
$data = str_replace('', '', $data);
}
if (preg_match('#]*>
#is', $data)) {
$data = preg_replace('#]*>
#is', '', $data);
}
return $data;
}
else {
return false;
}
}
/**
* 获取 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;
}
$html_content = mb_convert_encoding($html_content, 'UTF-8', 'gb2312');
总结
感谢各位的阅读,以上就是“PHP DOM乱码怎么办,解决方法是什么”的内容了,通过以上内容的阐述,相信大家对PHP DOM乱码怎么办,解决方法是什么已经有了进一步的了解,如果想要了解更多相关的内容,欢迎关注网络,网络将为大家推送更多相关知识点的文章。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: PHP DOM乱码怎么办,解决方法是什么
本文地址: https://pptw.com/jishu/652521.html
