这里有新鲜出炉的 PHP 教程,程序狗速度看过来!
PHP(外文名: Hypertext Preprocessor,中文名:"超文本预处理器")是一种通用开源脚本语言。语法吸收了 C 语言、Java 和 Perl 的特点,入门门槛较低,易于学习,使用广泛,主要适用于 web 开发领域。PHP 的文件后缀名为 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('#<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;
- }
- }
- /**
- * 获取 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');
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
来源: http://www.phperz.com/article/17/0805/341060.html