ArcherWong博客
首页
博客
php中使用curl
作者:ArcherWong
分类:php
时间:2019-01-03 21:37:36
阅读:324
[TOC] # 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
标签:
上一篇:
php中关于时间的总结
下一篇:
面向对象
文章分类
css
elasticsearch
git
golang
guacamole
javascript
letsencrypt
linux
nginx
other
php
python
vue
web
阅读排行
centos7.3配置guacamole
golang笔记---关联数组(map)
letsencrypt证书-管理工具certbot
golang笔记---template模板语法
nginx笔记-proxy_cache缓存详解
友情链接
node文件
laravel-vue
ArcherWong的博客园