//职位名称
preg_match_all('/
.*?(.*?)/s', $output, $title); $title[1];//链接 $title[2];//标题 //公司名称 preg_match_all('/
|
.*?(.*?)/s', $output, $company); $company[1];//链接 $company[2];//名字 //工作地点 preg_match_all('/
|
\s*(.*?)\s*/s', $output, $address); $address[1];//地点 //发布日期 preg_match_all('/ |
\s*(.*?)\s*/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);
http://www.bkjia.com/PHPjc/327097.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/327097.htmlTechArticlecurl可以说是php里一个非常强大的功能,每个php程序员都应该学习并熟悉curl,使用curl前确保你的php_curl扩展已经开启。 一、curl使用 例如:我...
|