php5.6 乱码,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');

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

以上就是本次给大家分享的关于java的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。

您可能感兴趣的文章:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值