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

php中文网
发布: 2016-06-23 13:23:14
原创
1101人浏览过

代码如下:

<?php$url = "http://zhidao.baidu.com/link?url=ptwcjotq02pjg-mjcnc-fkw8onoy9x8q0esrcfhdvjy47agzndncb-bcatngrgdt9yi0tvless_w0apj8vsk0atvkvhnydzadn0kv0bznau";echo fopen_url($url);function fopen_url($url) {     if (function_exists('curl_init'))	{         $curl_handle = curl_init();         curl_setopt($curl_handle, curlopt_url, $url);         curl_setopt($curl_handle, curlopt_connecttimeout,2);         curl_setopt($curl_handle, curlopt_returntransfer,1);         curl_setopt($curl_handle, curlopt_failonerror,1); 		curl_setopt($curl_handle, curlopt_timeout,2);        $file_content = curl_exec($curl_handle);		$encode = mb_detect_encoding($file_content, array("ascii","utf-8","gb2312","gbk","big5"));				if($encode != "utf-8")		{		   $file_content = mb_convert_encoding($file_content, "utf-8", $encode);		   //$file_content = iconv($encode,'utf-8//ignore',$file_content);		}        curl_close($curl_handle);     }	else	{         $file_content = '';     }     return $file_content; }?>
登录后复制


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



这什么原因造成的?

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

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

非常感谢!

Text Mark
Text Mark

处理文本内容的AI助手

Text Mark 81
查看详情 Text Mark


回复讨论(解决方案)

另外还有个别页面竟然curl_init回来是空白的数据,要多刷新几次才显示,参数值设置有问题?

返回的数据中有:

根据他就可知道页面编码

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

数据片段

没理由出现非法字符

CP936 是 GBK 的国际称谓

第一个问题,不是乱码,那是图片,curl抓取百度页面,会特意把某些文字转换成图片,防抓取。你查看网页元素,你就会发现,那些乱码其实是百度的图片地址。

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

第一个问题,不是乱码,那是图片,curl抓取百度页面,会特意把某些文字转换成图片,防抓取。你查看网页元素,你就会发现,那些乱码其实是百度的图片地址。

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

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号