时时商务社区

标题: php解决DOM乱码的方法示例代码 [打印本页]

作者: bewin83    时间: 2018-2-14 05:30

            前言
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-XML创建和解析XML文件
  • PHP XML操作类DOMDocument
  • PHP5中使用DOM控制XML实现代码
  • php中DOMDocument简单用法示例代码(XML创建、添加、删除、修改)
  • 用PHP读取和编写XML DOM的实现代码
  • php中使用DOM类读取XML文件的实现代码
  • php中DOMElement操作xml文档实例演示
  • php解析html类库simple_html_dom(详细介绍)
  • PHP使用DOMDocument类生成HTML实例(包含常见标签元素)
  • DOM基础及php读取xml内容操作的方法
            




    欢迎光临 时时商务社区 (http://bbs.4435.cn/) Powered by Discuz! X3.2