zoukankan      html  css  js  c++  java
  • php中使用curl

    1. curl简单使用步骤

    要使用cURL来发送url请求,具体步骤大体分为以下四步:

    • 1.初始化
    • 2.设置请求选项
    • 3.执行一个cURL会话并且获取相关回复
    • 4.释放cURL句柄,关闭一个cURL会话
    // 1. 初始化一个cURL会话
    $ch = curl_init();
    
    // 2. 设置请求选项, 包括具体的url
    curl_setopt($ch, CURLOPT_URL, "http://www.baidu.com");
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_HEADER, 0);
    
    // 3. 执行一个cURL会话并获取相关回复
    $response = curl_exec($ch);
    
    // 4. 释放cURL句柄,关闭一个cURL会话
    curl_close($ch);
    

    上述代码中使用到了四个函数

    • curl_init() 初始化CURL连接。
    • curl_exec() 执行CURL请求,如果没有错误发生,该函数的返回是对应URL返回的数据;如果发生错误,该函数返回 FALSE。
    • curl_setopt() 可以通过设定CURL函数库定义的选项来定制HTTP请求。上述代码片段中使用了三个重要的选项:
      • CURLOPT_URL 指定请求的URL;
      • CURLOPT_RETURNTRANSFER 设置为1表示稍后执行的curl_exec函数的返回是URL的返回字符串,而不是把返回字符串定向到标准输出并返回TRUE;
      • CURLLOPT_HEADER设置为0表示不返回HTTP头部信息。
    • curl_close() 关闭CURL连接。

    2. 错误处理

    可以处理response的结果,根据结果进一步操作

    $response = curl_exec($ch);
    
    if ($response  === FALSE) {
      echo "cURL 具体出错信息: " . curl_error($ch);
    }
    

    需要注意的是,判断输出是否为FALSE用的是全等号,这是为了区分返回空串和出错的情况。

    3. 获取curl请求的具体信息

    在curl_exec()函数执行之后,可以使用curl_getinfo()函数获取CURL请求输出的相关信息,如下面的例子

    curl_exec($ch);
    $curl_info= curl_getinfo($ch);
    
    echo "收到的http回复的code为: {$curl_info['http_code']}";
    

    curl_getinfo 的用法,参考地址 http://cn2.php.net/manual/zh/function.curl-getinfo.php

    语法

    mixed curl_getinfo ( resource $ch [, int $opt = 0 ] )
    

    上面有两个参数

    • ch 由 curl_init() 返回的 cURL 句柄。

    • opt 这个参数可能是以下常量之一:

    CURLINFO_EFFECTIVE_URL - 最后一个有效的URL地址
    CURLINFO_HTTP_CODE - 最后一个收到的HTTP代码
    CURLINFO_FILETIME - 远程获取文档的时间,如果无法获取,则返回值为“-1”
    CURLINFO_TOTAL_TIME - 最后一次传输所消耗的时间
    CURLINFO_NAMELOOKUP_TIME - 名称解析所消耗的时间
    CURLINFO_CONNECT_TIME - 建立连接所消耗的时间
    CURLINFO_PRETRANSFER_TIME - 从建立连接到准备传输所使用的时间
    CURLINFO_STARTTRANSFER_TIME - 从建立连接到传输开始所使用的时间
    CURLINFO_REDIRECT_TIME - 在事务传输开始前重定向所使用的时间
    CURLINFO_SIZE_UPLOAD - 以字节为单位返回上传数据量的总值
    CURLINFO_SIZE_DOWNLOAD - 以字节为单位返回下载数据量的总值
    CURLINFO_SPEED_DOWNLOAD - 平均下载速度
    CURLINFO_SPEED_UPLOAD - 平均上传速度
    CURLINFO_HEADER_SIZE - header部分的大小
    CURLINFO_HEADER_OUT - 发送请求的字符串
    CURLINFO_REQUEST_SIZE - 在HTTP请求中有问题的请求的大小
    CURLINFO_SSL_VERIFYRESULT - 通过设置CURLOPT_SSL_VERIFYPEER返回的SSL证书验证请求的结果
    CURLINFO_CONTENT_LENGTH_DOWNLOAD - 从Content-Length: field中读取的下载内容长度
    CURLINFO_CONTENT_LENGTH_UPLOAD - 上传内容大小的说明
    CURLINFO_CONTENT_TYPE - 下载内容的Content-Type:值,NULL表示服务器没有发送有效的Content-Type: header
    

    1、如果不设置第二个参数opt,curl_getinfo返回的是一个关联数组,包含以下数据

    url:网络地址。
    content_type:内容编码。
    http_code:HTTP状态码。
    header_size:header的大小。
    request_size:请求的大小。
    filetime:文件创建的时间。
    ssl_verify_result:SSL验证结果。
    redirect_count:跳转计数。
    total_time:总耗时。
    namelookup_time:DNS查询耗时。
    connect_time:等待连接耗时。
    pretransfer_time:传输前准备耗时。
    size_uplpad:上传数据的大小。
    size_download:下载数据的大小。
    speed_download:下载速度。
    speed_upload:上传速度。
    download_content_length:下载内容的长度。
    upload_content_length:上传内容的长度。
    starttransfer_time:开始传输的时间表。
    redirect_time:重定向耗时。
    

    2、如果设置了第二个参数,那么返回的只有指定的信息。

    例如设置$opt为CURLINFO_TOTAL_TIME,则curl_getinfo()函数只返回total_time,即总传输消耗的时间,在只需要关注某些传输信息时,设置$opt参数很有意义。

    4. 使用curl发送get请求

    这个比较简单,其实就是指定正确的url就可以了

    $url = 'https://www.google.com/search?ei=F0h1W8nkL6rJjwTRpYyoCA&q=php+curl&oq=php+curl&gs_l=psy-ab.3..35i39k1l2j0i67k1l2j0i203k1l3j0i67k1j0i203k1j0i67k1.326850.328536.0.328745.10.7.1.0.0.0.339.651.3-2.2.0....0...1c.1j4.64.psy-ab..7.3.656.0...0.8TB_OPcyWsY';
    
    //初始化
    $ch = curl_init();
    
    //设置选项,包括URL
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_HEADER, 0);
    
    //执行并获取HTML文档内容
    $output = curl_exec($ch);
    //释放curl句柄
    curl_close($ch);
    //打印获得的数据
    print_r($output);
    

    5. 使用curl发送post请求

    $url = "http://www.baidu.com";
    
    $post_data = array (
      "blog_name" => "test",
      "action" => "Submit"
    );
    
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_HEADER, false);
    
    
    // 设置请求为post类型
    curl_setopt($ch, CURLOPT_POST, 1);
    // 添加post数据到请求中
    curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
    
    // 执行post请求,获得回复
    $response= curl_exec($ch);
    curl_close($ch);
    
    echo $response;
    

    实际上我们上面用到了两个重要的参数

    • CURLOPT_POSTFIELDS 设置该选项为POST字符串数据就可以把请求放在正文中。
    • CURL_POST 设置了CURL_POST为true,标识这个请求是一个POST请求。

    6. 使用curl上传文件

    <?php
    $url = "/xx/yy";
    
    $post_data = ['myfile' => new CURLFILE($file_path), 'dir_path' => $dir_path];
    
    $ch = curl_init();
    curl_setopt($ch , CURLOPT_URL , $url);
    curl_setopt($ch , CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_HEADER, false);
    curl_setopt($ch , CURLOPT_POST, 1);
    curl_setopt($ch , CURLOPT_POSTFIELDS, $post_data);
    $output = curl_exec($ch);
    curl_close($ch);
    
    

    这里需要特别说明下,以下这种写法

    $post_data = array(
                // 需要注意的是,在路径前必须带上@,不然只会当做是简单的键值对
                'pic'   =>  '@'.realpath($path)
                'name'  =>  'issac'
            );
    
    

    只有在php5.5以下版本有效,换言之现在根本没有用,而且现在网上充斥的全是这种过时的失效版本,@字符什么,现在根本没有用了,很多资料并没有注明,害我调试了好久。

    所以为了兼容不同版本,可以参考这个方法

    function upload_file($url,$filename,$path,$type){
        //php 5.5以上的用法
        if (class_exists('CURLFile')) {
            $data = array('file' => new CURLFile(realpath($path),$type,$filename));
        } else {
            $data = array(
                'file'=>'@'.realpath($path).";type=".$type.";filename=".$filename
            );
        }
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_POST, true );
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
        curl_setopt($ch, CURLOPT_HEADER, false);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        $return_data = curl_exec($ch);
        curl_close($ch);
        echo $return_data;
    }
    

    参考

    http://cn2.php.net/manual/zh/function.curl-getinfo.php

    https://www.cnblogs.com/52fhy/p/4971707.html

    https://www.cnblogs.com/manongxiaobing/p/4698990.html

    https://www.jianshu.com/p/63b32ceea742

    https://my.oschina.net/forMemory/blog/374451

  • 相关阅读:
    疯狂学java的第七天
    疯狂学java的第六天
    疯狂学java的第五天
    学java的第四天
    学java的第三天
    javaSE_20_常用API(包装类丶BigInteger类丶BigDecimal类 )
    javaSE_19_常用API(String类丶StringBuffer类)
    javaSE_17_内部类丶常用的引用类型用法总结
    javaSE_15_package和import丶访问控制权限
    javaSE_14_抽象类丶接口
  • 原文地址:https://www.cnblogs.com/redirect/p/10066560.html
Copyright © 2011-2022 走看看