600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > PHP使用CURL实现多线程抓取网页 phpcurl多线程抓取

PHP使用CURL实现多线程抓取网页 phpcurl多线程抓取

时间:2023-01-26 03:23:00

相关推荐

PHP使用CURL实现多线程抓取网页 phpcurl多线程抓取

php教程|php手册

php,curl,多线程,curl

php教程-php手册

PHP使用CURL实现多线程抓取网页,phpcurl多线程抓取

asp退出源码,ubuntu卸载安装gcc,爬虫小偏方视频,管理信息系统用java和php,耀讯seolzw

PHP 利用 Curl Functions 可以完成各种传送文件操作,比如模拟浏览器发送GET,POST请求等等,受限于php语言本身不支持多线程,所以开发爬虫程序效率并不高,这时候往往需 要借助Curl Multi Functions 它可以实现并发多线程的访问多个url地址。既然 Curl Multi Function如此强大,能否用 Curl Multi Functions 来写并发多线程下载文件呢,当然可以,下面给出我的代码:

Asp传奇一条龙网站源码,vscode 补全代码,ubuntu系统如何写c语言,上传网页tomcat,sqlite3.bll,dz支付宝分润插件,移动端前端框架知乎,关于爬虫恐怖电影,ubuntu搭建php,SEO工具有(),统计网站模板,时时彩网页版计划源码,微信游戏模板,php淘宝客程序 apilzw

代码1:将获得的代码直接写入某个文件

音乐站源码,vscode git管理,mnn在ubuntu下编译安装,tomcat多例部署,sqlite2.2.1汉化,ecshop供应商插件,用得最多的前端框架,爬虫爬取用户信息,php下载txt,礼泉优化seo,网站摸板,js框架 多窗口打开网页,模板软件,windows 程序设计 源码lzw

$url) { $conn[$i] = curl_init($url); curl_setopt($conn[$i], CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)"); curl_setopt($conn[$i], CURLOPT_HEADER ,0); curl_setopt($conn[$i], CURLOPT_CONNECTTIMEOUT,60); curl_setopt($conn[$i], CURLOPT_FILE,$st); // 设置将爬取的代码写入文件 curl_multi_add_handle ($mh,$conn[$i]); } // 初始化do { curl_multi_exec($mh,$active); } while ($active); // 执行foreach ($urls as $i => $url) { curl_multi_remove_handle($mh,$conn[$i]); curl_close($conn[$i]); } // 结束清理curl_multi_close($mh); fclose($st); ?>

代码2:将获得的代码先放入变量,再写入某个文件

$url) { $conn[$i] = curl_init($url); curl_setopt($conn[$i], CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)"); curl_setopt($conn[$i], CURLOPT_HEADER ,0); curl_setopt($conn[$i], CURLOPT_CONNECTTIMEOUT,60); curl_setopt($conn[$i],CURLOPT_RETURNTRANSFER,true); // 设置不将爬取代码写到浏览器,而是转化为字符串 curl_multi_add_handle ($mh,$conn[$i]); } do { curl_multi_exec($mh,$active); } while ($active);foreach ($urls as $i => $url) { $data = curl_multi_getcontent($conn[$i]); // 获得爬取的代码字符串 fwrite($st,$data); // 将字符串写入文件。当然,也可以不写入文件,比如存入数据库 } // 获得数据变量,并写入文件 foreach ($urls as $i => $url) { curl_multi_remove_handle($mh,$conn[$i]); curl_close($conn[$i]); } curl_multi_close($mh); fclose($st); ?>

以上所述就是本文的全部内容了,希望大家能够喜欢。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。