• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

curl_init回来的编码如何判断?个别文字乱码求解

php 搞代码 3年前 (2022-01-24) 21次浏览 已收录 0个评论

curl_init回来的编码怎么判断?个别文字乱码求解!
代码如下:

<br /><?php<br />$url = "http://zhidao.baidu.com/link?url=pTwcJotQ02pjg-mjCnc-fkw8ONOY9x8q0ESrCFhdVJy47agZnDnCb-BCAtngRGDt9yi0TvleSS_w0aPj8Vsk0atVkVhNYdZADN0kv0BzNau";<br /><br />echo fopen_url($url);<br />function fopen_url($url) <br />{ <br />    if (function_exists('curl_init'))<br />	{ <br />        $curl_handle = curl_init(); <br />        curl_setopt($curl_handle, CURLOPT_URL, $url); <br />        curl_setopt($curl_handle, CURLOPT_CONNECTTIMEOUT,2); <br />        curl_setopt($curl_handle, CURLOPT_RETURNTRANSFER,1); <br />        curl_setopt($curl_handle, CURLOPT_FAILONERROR,1); <br />		curl_setopt($curl_handle, CURLOPT_TIMEOUT,2);<br />        $file_content = curl_exec($curl_handle);<br />		$encode = mb_detect_encoding($file_content, array("ASCII","UTF-8","GB2312","GBK","BIG5"));		<br />		if($encode != "UTF-8")<br />		{<br />		   <b>/本文来源gao@!dai!ma.com搞$$代^@码5网@</b><strong>搞代gaodaima码</strong>$file_content = mb_convert_encoding($file_content, "UTF-8", $encode);<br />		   //$file_content = iconv($encode,'utf-8//IGNORE',$file_content);<br />		}<br />        curl_close($curl_handle); <br />    }<br />	else<br />	{ <br />        $file_content = ''; <br />    } <br />    return $file_content; <br />}<br />?><br /><br />

个别字符竟然会乱码!奇怪,请看图

这什么原因造成的?

上面的代码貌似有误啊,原页面明明是GB2312 缺判断出是CP936,无语啊

请帮忙看看上面代码是不是需要完善一下

非常感谢!
——解决思路———————-
返回的数据中有:
<meta http-equiv=”content-type” content=”text/html;charset=gbk” />
根据他就可知道页面编码

没有时才需要编程判断
mb_detect_encoding 判断常有失误,所以又增加了 mb_check_encoding 函数

数据片段

没理由出现非法字符

CP936 是 GBK 的国际称谓
——解决思路———————-
第一个问题,不是乱码,那是图片,curl抓取百度页面,会特意把某些文字转换成图片,防抓取。你查看网页元素,你就会发现,那些乱码其实是百度的图片地址。

第二个问题,你把超时时间设置大点,就好了,可能是你网络问题。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:curl_init回来的编码如何判断?个别文字乱码求解

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址