PHP CURL整理

1、初识curl

curl是利用URL语法在命令行方式下工作的开源文件传输工具。它被广泛应用在Unix、多种Linux发行版中,并且有DOS和Win32、Win64下的移植版本。

2、php curl 功能描述

  • curl_close — 关闭 cURL 会话
  • curl_copy_handle — 复制一个cURL句柄和它的所有选项
  • curl_errno — 返回最后一次的错误代码
  • curl_error — 返回当前会话最后一次错误的字符串
  • curl_escape — 使用 URL 编码给定的字符串
  • curl_exec — 执行 cURL 会话
  • curl_file_create — 创建一个 CURLFile 对象
  • curl_getinfo — 获取一个cURL连接资源句柄的信息
  • curl_init — 初始化 cURL 会话
  • curl_multi_add_handle — 向curl批处理会话中添加单独的curl句柄
  • curl_multi_close — 关闭一组cURL句柄
  • curl_multi_errno — 返回上一次 curl 批处理的错误码
  • curl_multi_exec — 运行当前 cURL 句柄的子连接
  • curl_multi_getcontent — 如果设置了CURLOPT_RETURNTRANSFER,则返回获取的输出的文本流
  • curl_multi_info_read — 获取当前解析的cURL的相关传输信息
  • curl_multi_init — 返回一个新cURL批处理句柄
  • curl_multi_remove_handle — 移除cURL批处理句柄资源中的某个句柄资源
  • curl_multi_select — 等待所有cURL批处理中的活动连接
  • curl_multi_setopt — 为 cURL 并行处理设置一个选项
  • curl_multi_strerror — 返回字符串描述的错误代码
  • curl_pause — 暂停和取消暂停一个连接。
  • curl_reset — 重置一个 libcurl 会话句柄的所有的选项
  • curl_setopt_array — 为 cURL 传输会话批量设置选项
  • curl_setopt — 设置 cURL 传输选项
  • curl_share_close — 关闭 cURL 共享句柄
  • curl_share_errno — Return the last share curl error number
  • curl_share_init — 初始化一个 cURL 共享句柄。
  • curl_share_setopt — 为 cURL 共享句柄设置选项。
  • curl_share_strerror — Return string describing the given error code
  • curl_strerror — 返回错误代码的字符串描述
  • curl_unescape — 解码给定的 URL 编码的字符串
  • curl_version — 获取 cURL 版本信息

3、打印请求句柄 获取请求详细信息

1.url:网络地址。
2.content_type:内容编码。
3.http_code:HTTP状态码。
4.header_size:header的大小。
5.request_size:请求的大小。
6.filetime:文件创建的时间。
7.ssl_verify_result:SSL验证结果。
8.redirect_count:跳转计数。
9.total_time:总耗时。
10.namelookup_time:DNS查询耗时。
11.connect_time:等待连接耗时。
12.pretransfer_time:传输前准备耗时。
13.size_uplpad:上传数据的大小。
14.size_download:下载数据的大小。
15.speed_download:下载速度。
16.speed_upload:上传速度。
17.download_content_length:下载内容的长度。
18.upload_content_length:上传内容的长度。
19.starttransfer_time:开始传输的时间表。
20.redirect_time:重定向耗时。

4、最简单 GET 请求

$ch = curl_init();  // 初始化
curl_setopt($ch,CURLOPT_URL,"http://www.devdo.net"); //  设置URL
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); //显示输出结果 TRUE 将curl_exec()获取的信息以字符串返回,而不是直接输出。
curl_setopt($ch,CURLOPT_HEADER,1); //返回response头部信息
$output = curl_exec($ch);//执行
curl_close($ch);//关闭

5、封装函数

   /**
     * 发送请求
     * @param $url  请求地址
     * @param string $post 默认GET请求
     * @param $headers  请求头
     * @param $body  请求体
     * @return mixed
     */
    public function curl($url,$post='',$headers,$body)
    {
        $curl = curl_init();

        curl_setopt($curl, CURLOPT_URL ,$url); // 设置请求的路径

        if($post){
            curl_setopt($curl, CURLOPT_POST, 1); //设置POST提交
            if(is_array($body)){
                curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($body));
            }else{
                curl_setopt($curl, CURLOPT_POSTFIELDS, $body);
            }
        }
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); //显示输出结果  //TRUE 将curl_exec()获取的信息以字符串返回,而不是直接输出。
        curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置cURL允许执行的最长秒数
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE); // https请求 不验证证书和hosts
        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);//设为0表示不检查证书 设为1表示检查证书中是否有CN(common name)字段 设为2表示在1的基础上校验当前的域名是否与CN匹配
        //提交数据
        curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
        //执行请求
        $data = $data_str = curl_exec($curl);
        $err = curl_error($curl);
        curl_close($curl);
        if($err) {
            $curlParam = is_array($body) ? http_build_query($body) : $body;
            $logdata = 'url=>'.$url."\n".
                'param=>'.$curlParam."\n".
                'result=>'.$data;
            Log::error('', 'remotecall', $logdata);//发生错误  记录日志
            
        }

        return $data;

    }

你可能感兴趣的:(PHP CURL整理)