代码如下:
<?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; }?>
另外还有个别页面竟然curl_init回来是空白的数据,要多刷新几次才显示,参数值设置有问题?
返回的数据中有:
根据他就可知道页面编码
没有时才需要编程判断
mb_detect_encoding 判断常有失误,所以又增加了 mb_check_encoding 函数
数据片段
没理由出现非法字符
CP936 是 GBK 的国际称谓
第一个问题,不是乱码,那是图片,curl抓取百度页面,会特意把某些文字转换成图片,防抓取。你查看网页元素,你就会发现,那些乱码其实是百度的图片地址。
第二个问题,你把超时时间设置大点,就好了,可能是你网络问题。
第一个问题,不是乱码,那是图片,curl抓取百度页面,会特意把某些文字转换成图片,防抓取。你查看网页元素,你就会发现,那些乱码其实是百度的图片地址。
第二个问题,你把超时时间设置大点,就好了,可能是你网络问题。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号