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 相关文章推荐
完美实现GIF动画缩略图的php代码
Jan 02 PHP
在smarty模板中使用PHP函数的方法
Apr 23 PHP
PHP缩略图等比例无损压缩,可填充空白区域补充色
Jun 10 PHP
改写函数实现PHP二维/三维数组转字符串
Sep 13 PHP
phpexcel导入excel数据使用方法实例
Dec 24 PHP
PHP实现视频文件上传完整实例
Aug 28 PHP
php快速查找数据库中恶意代码的方法
Apr 01 PHP
PHP解压ZIP文件到指定文件夹的方法
Nov 17 PHP
PHP使用PHPExcel实现批量上传到数据库的方法
Jun 08 PHP
Laravel框架使用技巧之使用url()全局函数返回前一个页面的地址方法详解
Apr 06 PHP
一文看懂PHP进程管理器php-fpm
Jun 01 PHP
宝塔面板出现“open_basedir restriction in effect. ”的解决方法
Mar 14 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
PHP集成百度Ueditor 1.4.3
2014/11/23 PHP
PHP 绘制网站登录首页图片验证码
2016/04/12 PHP
PHP简单遍历对象示例
2016/09/28 PHP
js调用webservice中的方法实现思路及代码
2013/02/25 Javascript
使用js检测浏览器的实现代码
2013/05/14 Javascript
jquery ajax实现下拉框三级无刷新联动,且保存保持选中值状态
2013/10/29 Javascript
同域jQuery(跨)iframe操作DOM(示例代码)
2013/12/13 Javascript
二叉树的非递归后序遍历算法实例详解
2014/02/07 Javascript
javascript怎么禁用浏览器后退按钮
2014/03/27 Javascript
JavaScript中对象属性的添加和删除示例
2014/05/12 Javascript
jquery队列函数用法实例
2014/12/16 Javascript
javascript实现当前页导航激活的方法
2015/02/27 Javascript
jQuery制作简洁的图片轮播效果
2015/04/03 Javascript
js中setTimeout()与clearTimeout()用法实例浅析
2015/05/12 Javascript
分享15个大家都熟知的jquery小技巧
2015/12/02 Javascript
AngularJS 使用 UI Router 实现表单向导
2016/01/29 Javascript
jQuery图片加载显示loading效果
2016/11/04 Javascript
详解Angular 4.x NgIf 的用法
2017/05/22 Javascript
详解Vue.js iview实现树形权限表(可扩展表)
2018/09/30 Javascript
Vue 中 a标签上href无法跳转的解决方式
2019/11/12 Javascript
javascript实现多边形碰撞检测
2020/10/24 Javascript
Python框架Flask的基本数据库操作方法分析
2018/07/13 Python
基于Django框架利用Ajax实现点赞功能实例代码
2018/08/19 Python
pyQt5实时刷新界面的示例
2019/06/25 Python
Python大数据之网络爬虫的post请求、get请求区别实例分析
2019/11/16 Python
python GUI库图形界面开发之PyQt5窗口控件QWidget详细使用方法
2020/02/26 Python
Python MySQL 日期时间格式化作为参数的操作
2020/03/02 Python
Python通过两个dataframe用for循环求笛卡尔积
2020/04/29 Python
世界最大域名注册商:GoDaddy
2016/07/24 全球购物
销售人员求职的自我评价分享
2014/03/15 职场文书
幼儿园大班毕业教师寄语
2014/04/03 职场文书
团代会开幕词
2015/01/28 职场文书
Oracle 数据仓库ETL技术之多表插入语句的示例详解
2021/04/12 Oracle
用 Python 元类的特性实现 ORM 框架
2021/05/19 Python
Python各协议下socket黏包问题原理
2022/04/12 Python
python 镜像环境搭建总结
2022/09/23 Python