php DOM文字化けを解決する方法例コード

2464 ワード

前言
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');

まとめ
以上はこの文章のすべての内容で、本文の内容がみんなの学习あるいは仕事に対して一定の助けをもたらすことができることを望んで、もし疑问があればみんなは伝言を残して交流することができます.