1. function curl_multi($urls) {
  2. if (!is_array($urls) or count($urls) == 0) {
  3. return false;
  4. }
  5. $num=count($urls);
  6. $curl = $curl2 = $text = array();
  7. $handle = curl_multi_init();
  8. function createCh($url) {
  9. $ch = curl_init();
  10. curl_setopt ($ch, CURLOPT_URL, $url);
  11. curl_setopt ($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1; Trident/7.0; rv:11.0) like Gecko');//设置头部
  12. curl_setopt ($ch, CURLOPT_REFERER, $url); //设置来源
  13. curl_setopt ($ch, CURLOPT_ENCODING, "gzip"); // 编码压缩
  14. curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
  15. curl_setopt ($ch, CURLOPT_FOLLOWLOCATION, 1);//是否采集301、302之后的页面
  16. curl_setopt ($ch, CURLOPT_MAXREDIRS, 5);//查找次数,防止查找太深
  17. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); // 对认证证书来源的检查
  18. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); // 从证书中检查SSL加密算法是否存在
  19. curl_setopt ($ch, CURLOPT_TIMEOUT, 20);
  20. curl_setopt ($ch, CURLOPT_HEADER, 0);//输出头部
  21. return $ch;
  22. }
  23. foreach($urls as $k=>$v){
  24. $url=$urls[$k];
  25. $curl[$k] = createCh($url);
  26. curl_multi_add_handle ($handle,$curl[$k]);
  27. }
  28. $active = null;
  29. do {
  30. $mrc = curl_multi_exec($handle, $active);
  31. } while ($mrc == CURLM_CALL_MULTI_PERFORM);
  32. while ($active && $mrc == CURLM_OK) {
  33. if (curl_multi_select($handle) != -1) {
  34. usleep(100);
  35. }
  36. do {
  37. $mrc = curl_multi_exec($handle, $active);
  38. } while ($mrc == CURLM_CALL_MULTI_PERFORM);
  39. }
  40. foreach ($curl as $k => $v) {
  41. if (curl_error($curl[$k]) == "") {
  42. $text[$k] = (string) curl_multi_getcontent($curl[$k]);
  43. }
  44. curl_multi_remove_handle($handle, $curl[$k]);
  45. curl_close($curl[$k]);
  46. }
  47. curl_multi_close($handle);
  48. return $text;
  49. }
  50. $urls=array('http://www.baidu.com',
  51. 'http://www.baidu.com',
  52. 'http://www.baidu.com',
  53. 'http://www.baidu.com',
  54. 'http://www.baidu.com',
  55. 'http://www.baidu.com',
  56. 'http://www.baidu.com',
  57. 'http://www.baidu.com'
  58. );
  59. $res=curl_multi($urls);
  60. print_r($res);

PHP 多线程采集的更多相关文章

  1. Python多线程采集百度相关搜索关键词

    百度相关搜索关键词抓取,读取txt关键词,导出txt关键词 #百度相关搜索关键词抓取,读取txt关键词,导出txt关键词   # -*- coding=utf-8 -*- import request ...

  2. python3 多线程 采集 xpath

    #!/usr/bin/python # -*- coding: UTF-8 -*- '''Thread3 多线程测试采集''' import threading,time,queue,Mongo_ut ...

  3. python多线程采集

    import requests import json import threading Default_Header = { #具体请求头自己去弄 } _session=requests.sessi ...

  4. PHP使用CURL_MULTI实现多线程采集

    $connomains = array( "http://www.baidu.com/", "http://www.hao123.com/", "ht ...

  5. python多线程采集图片

    cmd中运行 >python untitled2.py    图片的网站 import requests import threading from bs4 import BeautifulSo ...

  6. PHP cURL应用实现模拟登录与采集使用方法详解

    对于做过数据采集的人来说,cURL一定不会陌生.虽然在PHP中有file_get_contents函数可以获取远程链接的数据,但是它的可控制性太差了,对于各种复杂情况的采集情景,file_get_co ...

  7. 多线程实际运用<第七篇>

    1.单线程采集100个页面 class Program { static int i = 6991275; static void Main(string[] args) { Stopwatch sw ...

  8. PHP cURL实现模拟登录与采集使用方法详解教程

    来源:http://www.zjmainstay.cn/php-curl 本文将通过案例,整合浏览器工具与PHP程序,教你如何让数据 唾手可得 . 对于做过数据采集的人来说,cURL一定不会陌生.虽然 ...

  9. 转载 多线程实际运用<第七篇>

    多线程实际运用<第七篇> 1.单线程采集100个页面 class Program { static int i = 6991275; static void Main(string[] a ...

随机推荐

  1. Qt creator 最常用的13个快捷键

    alt +enter // 自动创建类的定义 F1 // 查看帮助,文档 F2 // 快速到变量声明 Shift + F2 // 函数的声明和定义之间快速切换 F4 // 在 cpp 和 h 文件切换 ...

  2. 【坚持】Selenium+Python学习之从读懂代码开始 DAY2

    2018/05/10 [来源:菜鸟教程](http://www.runoob.com/python3/python3-examples.html) #No.1 # 二次方程式 ax**2 + bx + ...

  3. 梯度消失&&梯度爆炸

    转载自: https://blog.csdn.net/qq_25737169/article/details/78847691 前言 本文主要深入介绍深度学习中的梯度消失和梯度爆炸的问题以及解决方案. ...

  4. Python20-Day02

    1.数据 数据为什么要分不同的类型 数据是用来表示状态的,不同的状态就应该用不同类型的数据表示: 数据类型 数字(整形,长整形,浮点型,复数),字符串,列表,元组,字典,集合 2.字符串 1.按索引取 ...

  5. 20172330 2017-2018-1 《Java程序设计》第十一周学习总结

    20172330 2017-2018-1 <程序设计与数据结构>第十一周学习总结 教材学习内容总结 本周的学习内容为集合 Android简介 Android操作系统是一种多用户的Linux ...

  6. Java中的多态,引用类型的转换

    1.多态分为引用多态和方法多态,见测试类 package com.wangcf; //父类 public class Animal { public void eat(){ System.out.pr ...

  7. psp项目计划

    日期/任务 听课 编写程序 阅读书籍 查阅资料 日总计 周一 2h 0.5h     2.5 周二     1h   1 周三     1h     周四 2h 0.5h     2.5 周五   3 ...

  8. 基础系列(1)—— NET框架及C#语言

    一.在.NET之前的编程世界 C#语言是在微软公司的.NET框架上开发程序而设计的,首先作者给大家纠正了一下C#的正确发音:See Sharp (一) 20世纪90年代末的Windows编程 这时大多 ...

  9. 软件图书,偏.net方向

    深入理解计算机系统(原书第2版) 作者:Randal E.Bryant:1981年在麻省理工学院获计算机科学博士学位,现任美国卡内基·梅隆大学计算机学院院长 内容: 深入浅出地介绍了处理器.编译器.操 ...

  10. 0527 SCRUM团队项目7.0

    Sprint回顾 让我们一次比一次做得更好.   1.回顾组织 主题:“我们怎样才能在下个sprint中做的更好?” 时间:设定为1至2个小时. 参与者:整个团队. 场所:能够在不受干扰的情况下讨论. ...