php curl的深入解析


Posted in PHP onJune 02, 2013

curl可以说是php里一个非常强大的功能,每个php程序员都应该学习并熟悉curl,使用curl前确保你的php_curl扩展已经开启。

一、curl使用
例如:我们采集深圳智联招聘上PHP招聘的第一页信息

$url='http://sou.zhaopin.com/jobs/searchresult.ashx?jl=%E6%B7%B1%E5%9C%B3&kw=php&sm=0&p=1';
//初始化
$ch = curl_init();
//设置选项,包括URL
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//不自动输出内容
curl_setopt($ch, CURLOPT_HEADER, 0);//不返回头部信息
//执行curl
$output = curl_exec($ch);
//错误提示
if(curl_exec($ch) === false){
    die(curl_error($ch));
}
//释放curl句柄
curl_close($ch);
header('Content-type: text/html; charset=utf-8');
echo $output;

当然我们必须对返回的数据使用<<正则表达式>>处理,找出我们想要的那一部分,然后根据你的需要把数据填充到你网站里
//职位名称
preg_match_all('/<td class="Jobname">.*?<a\s*href="(.*?)"\starget="_blank">(.*?)<\/a>/s', $output, $title);
$title[1];//链接
$title[2];//标题
//公司名称
preg_match_all('/<td class="Companyname">.*?<a href="(.*?)"\starget="_blank">(.*?)<\/a>/s', $output, $company);
$company[1];//链接
$company[2];//名字
//工作地点
preg_match_all('/<td class="Companyaddress">\s*(.*?)\s*<\/td>/s', $output, $address);
$address[1];//地点
//发布日期
preg_match_all('/<td class="releasetime">\s*(.*?)\s*<\/td>/s', $output, $time);
$time[1];//时间
var_dump($time[1]);

二、常用功能
curl的核心是通过设置各种选项来达到各种功能,这里我们介绍几种常用的选项。
1.post数据
$post=array(
'uid'=>'test',
'pwd'=>'curl123'
);
curl_setopt($ch, CURLOPT_POST, 1);//设置为POST方式
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($post));//POST数据

2.cookie
$savefile=dirname(__FILE__).'save.txt';
$getfile=dirname(__FILE__).'get.txt';
//可以分开使用
curl_setopt($ch, CURLOPT_COOKIEJAR, $savefile); //保存  
curl_setopt($ch, CURLOPT_COOKIEFILE, $getfile); //读取

3.伪造IP、来路
curl_setopt($ch, CURLOPT_HTTPHEADER, array('X-FORWARDED-FOR:8.8.8.8', 'CLIENT-IP:8.8.8.8'));//构造IP  
curl_setopt($ch, CURLOPT_REFERER, "http://www.baidu.com");//构造来路 

curl_setopt选项大全,详见PHP手册:http://www.php.net/manual/zh/function.curl-setopt.php
三、多线程
官方示例
// 创建一对cURL资源
$ch1 = curl_init();
$ch2 = curl_init();
// 设置URL和相应的选项
curl_setopt($ch1, CURLOPT_URL, "http://www.example.com/");
curl_setopt($ch1, CURLOPT_HEADER, 0);
curl_setopt($ch2, CURLOPT_URL, "http://www.php.net/");
curl_setopt($ch2, CURLOPT_HEADER, 0);
// 创建批处理cURL句柄
$mh = curl_multi_init();
// 增加2个句柄
curl_multi_add_handle($mh,$ch1);
curl_multi_add_handle($mh,$ch2);
$running=null;
// 执行批处理句柄
do {
    usleep(10000);
    curl_multi_exec($mh,$running);
} while ($running > 0);
// 关闭全部句柄
curl_multi_remove_handle($mh, $ch1);
curl_multi_remove_handle($mh, $ch2);
curl_multi_close($mh);

PHP 相关文章推荐
php adodb连接mssql解决乱码问题
Jun 12 PHP
php 安全过滤函数代码
May 07 PHP
php返回相对时间(如:20分钟前,3天前)的方法
Apr 14 PHP
PHP版本常用的排序算法汇总
Dec 20 PHP
Zend Framework实现Zend_View集成Smarty模板系统的方法
Mar 05 PHP
PHP实现适用于文件内容操作的分页类
Jun 15 PHP
PHP+Ajax验证码验证用户登录
Jul 20 PHP
PHP抓取远程图片(含不带后缀的)教程详解
Oct 21 PHP
浅谈PHP的exec()函数无返回值排查方法(必看)
Mar 31 PHP
关于php 高并发解决的一点思路
Apr 16 PHP
PHP中phar包的使用教程
Jun 14 PHP
PHP实时统计中文字数和区别
Feb 28 PHP
Window 7/XP 安装Apache 2.4与PHP 5.4 的过程详解
Jun 02 #PHP
web站点获取用户IP的安全方法 HTTP_X_FORWARDED_FOR检验
Jun 01 #PHP
获取用户Ip地址通用方法与常见安全隐患(HTTP_X_FORWARDED_FOR)
Jun 01 #PHP
php源代码安装常见错误与解决办法分享
May 28 #PHP
如何批量替换相对地址为绝对地址(利用bat批处理实现)
May 27 #PHP
php 深入理解strtotime函数的使用详解
May 23 #PHP
如何使用PHP计算上一个月的今天
May 23 #PHP
You might like
Zend的AutoLoad机制介绍
2012/09/27 PHP
php inc文件使用的风险和注意事项
2013/11/12 PHP
php简单的留言板与回复功能具体实现
2014/02/19 PHP
php实现的单一入口应用程序实例分析
2015/09/23 PHP
PHP实现文件上传下载实例
2016/10/18 PHP
Laravel 修改验证异常的响应格式实例代码详解
2020/05/25 PHP
Firefox下提示illegal character并出现乱码的原因
2010/03/25 Javascript
JQuery入门——事件切换之toggle()方法应用介绍
2013/02/05 Javascript
jQuery数据缓存功能的实现思路及简单模拟
2013/05/27 Javascript
javascript学习笔记(一)基础知识
2014/09/30 Javascript
javascript实现滑动解锁功能
2014/12/31 Javascript
使用js画图之画切线
2015/01/12 Javascript
jquery事件preventDefault()方法用法实例
2015/01/16 Javascript
JS实现状态栏跑马灯文字效果代码
2015/10/24 Javascript
JS HTML5实现拖拽移动列表效果
2020/08/27 Javascript
gulp加批处理(.bat)实现ng多应用一键自动化构建
2017/02/16 Javascript
javascript实现非常简单的小数取整功能示例
2017/06/13 Javascript
微信小程序实现的贪吃蛇游戏【附源码下载】
2018/01/03 Javascript
Hexo已经看腻了,来手把手教你使用VuePress搭建个人博客
2018/04/26 Javascript
jQuery解析json格式数据示例
2018/09/01 jQuery
从0到1搭建element后台框架优化篇(打包优化)
2019/05/12 Javascript
v-slot和slot、slot-scope之间相互替换实例
2020/09/04 Javascript
[01:03:51]2018DOTA2亚洲邀请赛 4.7 淘汰赛 VP vs LGD 第三场
2018/04/09 DOTA
[49:12]完美世界DOTA2联赛PWL S2 Magma vs GXR 第二场 11.29
2020/12/02 DOTA
实例说明Python中比较运算符的使用
2015/05/13 Python
单身旅行者的单身假期:Just You
2018/04/08 全球购物
一套PHP的笔试题
2013/05/31 面试题
介绍一下XMLHttpRequest对象的常用方法和属性
2013/05/24 面试题
2014年教师节寄语
2014/04/03 职场文书
完整版商业计划书
2014/09/15 职场文书
2015元旦标语横幅
2014/12/09 职场文书
小学二年级数学教学计划
2015/01/20 职场文书
物业客服专员岗位职责
2015/04/07 职场文书
实习证明模板
2015/06/16 职场文书
JavaScript实现九宫格拖拽效果
2022/06/28 Javascript
Spring中bean集合注入的方法详解
2022/07/07 Java/Android