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实现

<?php
    $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实现

<?php
    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;
    }   

       比如把URL参数传递为http://www.baidu.com,data参数传递为array(‘uid‘=>‘122139342‘, ‘password‘=>‘wfiw7482f‘),此时var_dump一下$result,如下

      

      返回了一个字符串,当然这只是测试。

      curl_getinfo函数获取的事本次访问资源句柄的信息,大概有访问的URL、访问状态码、头大小、连接时间、跳转的URL、访问的本地IP和接口等等,如下

      

       暂时到这,日后补充其他curl可以实现的功能。

 

      

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。