]*charset="?gb2312"[^>]*>#', $) を使用します。 data)」の方法で文字化けを解決できます。"/> ]*charset="?gb2312"[^>]*>#', $) を使用します。 data)」の方法で文字化けを解決できます。">

ホームページ >バックエンド開発 >PHPの問題 >php dom文字化け問題の解決方法

php dom文字化け問題の解決方法

藏色散人
藏色散人オリジナル
2020-08-05 09:41:051464ブラウズ

php dom 文字化けコードの解決策: まず、URL ページ情報をリクエストする「curl_get」メソッドを定義し、次に「preg_match('#]*charset="?gb2312"[^>] *」を使用します。 >#', $data)」メソッドで文字化けを解決できます。 [^>

php dom文字化け問題の解決方法

推奨事項: 「PHP ビデオ チュートリアル

DOM は、比較的新しい XML および HTML 処理です。 PHP クラスを使用すると、DOM ツリーを JavaScript と同じように簡単に操作できます。XML の処理方法については、インターネット上に詳しい情報があります。今日の記事では、DOM の文字化けを解決する PHP の方法を紹介します。以下で言うことはあまりありません。解決策を見てください。 . .

解決策は次のとおりです

/**
 * 请求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(&#39;#<meta[^>]*charset="?gb2312"[^>]*>#&#39;, $data)) {
      $data = iconv("gb2312","utf-8//IGNORE",$data);
      $data = preg_replace(&#39;#<meta[^>]*charset="?gb2312"[^>]*>#is&#39;, &#39;<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">&#39;, $data);
    }
    if (!preg_match(&#39;#<meta charset="utf-8"[^>]*>#is&#39;, $data)) {
      $data = str_replace(&#39;<head>&#39;, &#39;<head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">&#39;, $data);
    }
    if (preg_match(&#39;#<meta charset="utf-8"[^>]*>#is&#39;, $data)) {
      $data = preg_replace(&#39;#<meta charset="utf-8"[^>]*>#is&#39;, &#39;<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">&#39;, $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, &#39;请求失败&#39;);
    return false;
  }
  $dom = new DOMDocument(&#39;1.0&#39;, &#39;utf-8&#39;);
  libxml_use_internal_errors(true);
  $dom->loadHTML($html_content);
  return $dom;
}
$html_content = mb_convert_encoding($html_content, &#39;UTF-8&#39;, &#39;gb2312&#39;);

以上がphp dom文字化け問題の解決方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。