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