PHP之curl


当我第一次接触curl的时候,看文档,以及网上search各种资料,官方(http://cn2.php.net/manual/en/intro.curl.php)的解释是,这是某大牛写的一个libcurl库,PHP支持该扩展库,允许我们以各种不同的协议(http、https、ftp、telnet、file...)访问各种不同的服务器,支持post、put、ftp或基于表单的文件上传,支持cookie、代理等等。

好像还是似懂非懂,我觉得最简单的解释是,curl是一个工具集,由libcurl扩展库支持,包含一些函数,使用这些函数可以模拟我们来访问某些地址,也就是,我们手动在浏览器地址栏里面输入http://www.baidu.com,来访问百度,curl就可以代替这种手动操作,以程序的形式来实现这一过程,这个操作、过程得到的结果,是浏览器给了我们一个百度搜索的首页。

既然curl是一个工具集,有很多函数可供调用,可以想象成,在地址栏输入URL(可能会带一些参数),当输入完点击回车的时候,相当于调用了某些函数,这些函数在百度某台或某几台服务器上的脚本上写着,函数运行完后会有某种效果,比如返回了值,或者没返回值,或者打印了一些东西,在这里呈现了一个页面给你,而curl能实现的功能,比简单展示一个页面多得多,这些各自不同的功能是通过curl_setopt函数来实现的。比如在接SDK的时候,别人提供的是访问地址形式的API,这时curl就大显身手。

1.get实现

复制代码

$url = 'http://www.somesite.com';

$data = array('username'=>'Peter', 'password'=>12345);

function get($url, $data = array()){

$ch = curl_init(); // 初始化一个curl资源类型变量

/*设置访问的选项*/

curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); // 启用时会将服务器服务器返回的Location: 放在header中递归的返回给服务器

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true ); // 将获得的数据返回而不是直接在页面上输出

curl_setopt($ch, CURLOPT_PROTOCOLS, CURLPROTO_HTTP ); // 设置访问地址用的协议类型为HTTP

curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 15); // 访问的超时时间限制为15s

$url = url.'?'.http_build_query($data);

curl_setopt($ch, CURLOPT_URL, $url); // 设置即将访问的URL

$result = curl_exec($ch); // 执行本次访问,返回一个结果

// ... // 针对结果的正确与否做一些操作

return $result;

}

// $result = get(%url, $data); // 调用

复制代码

2.post实现

复制代码

function post($url, $data = array()){

$ch = curl_init();

curl_setopt($ch, CURLOPT_POST, true); // 设置为post传递形式

curl_setopt($ch, CURLOPT_POSTFIELDS, $data); // 设置post传递的数据

curl_setopt($ch, CURLOPT_URL, $url);

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); // 设置数据以文件流的形式返回

curl_setopt($ch, CURLOPT_USERAGENT, ''); // 将用户代理置空

curl_setopt($ch, CURLOPT_HEADER, false); // 设置不显示头信息

$result = curl_exec($ch);

$info = curl_getinfo($ch); // 获取本次访问资源的相关信息

return $result;

}

09-19 05:47