分享编程~
 

PHP封装请求接口类curl封装类支持文件上传

为了开发方便PHP封装简单易用请求接口类curl封装类支持多文件上传,支持json数据传输,直接实例化类调用方法传参即可,省掉了频繁写curl相关参数配置的麻烦…

天天特卖抢好货

通常php中curl请求接口方式一般为:


/**
 * Notes:CURL GET请求
 */
function httpGet($requestUrl){
	$urlRs = curl_init();
	curl_setopt($urlRs, CURLOPT_URL, $requestUrl);
	curl_setopt($urlRs, CURLOPT_FAILONERROR, false);
	curl_setopt($urlRs, CURLOPT_RETURNTRANSFER, true);
	curl_setopt($urlRs, CURLOPT_TIMEOUT, 10); 		 // 读取URL的超时时间 10s
	curl_setopt($urlRs, CURLOPT_CONNECTTIMEOUT, 10); //连接超时时间 10s
	//判断是否是HTTPS请求
	if(strlen($requestUrl) > 5 && strtolower(substr($requestUrl, 0, 5)) == "https" ){
		curl_setopt($urlRs, CURLOPT_SSL_VERIFYPEER, false);
		curl_setopt($urlRs, CURLOPT_SSL_VERIFYHOST, 0);
	}
	//发送消息,获取响应
	$response = curl_exec($urlRs);
	//关闭连接
	curl_close($urlRs);
	return $response;
}

/**
 * Notes:CURL POST请求
 */
function httpPost($requestUrl, $postData){
	$urlRs = curl_init();
	curl_setopt($urlRs, CURLOPT_URL, $requestUrl);
	curl_setopt($urlRs, CURLOPT_FAILONERROR, false);
	curl_setopt($urlRs, CURLOPT_RETURNTRANSFER, true);
	curl_setopt($urlRs, CURLOPT_POST, true);
	curl_setopt($urlRs, CURLOPT_POSTFIELDS, $postData);
	curl_setopt($urlRs, CURLOPT_TIMEOUT, 10); 		 // 读取URL的超时时间 10s
	curl_setopt($urlRs, CURLOPT_CONNECTTIMEOUT, 10); //连接超时时间 10s
	//判断是否是HTTPS请求
	if(strlen($requestUrl) > 5 && strtolower(substr($requestUrl, 0, 5)) == "https" ){
		curl_setopt($urlRs, CURLOPT_SSL_VERIFYPEER, false);
		curl_setopt($urlRs, CURLOPT_SSL_VERIFYHOST, 0);
	}
	//发送消息,获取响应
	$reponse = curl_exec($urlRs);
	//关闭连接
	curl_close($urlRs);
	return $reponse;
}

/**
 * Notes:json格式 POST请求
 */
function jsonPost($requestUrl, $postData){
	$urlRs = curl_init();
	$headers = array(
					"Content-type:application/json;charset='utf-8'",
					"Accept: application/json",
					"Cache-Control: no-cache",
					"Pragma: no-cache"); // 注意请求头配置
	curl_setopt($urlRs, CURLOPT_HTTPHEADER, $headers);
	curl_setopt($urlRs, CURLOPT_URL, $requestUrl);
	curl_setopt($urlRs, CURLOPT_FAILONERROR, false);
	curl_setopt($urlRs, CURLOPT_RETURNTRANSFER, true);
	curl_setopt($urlRs, CURLOPT_POST, true);
	curl_setopt($urlRs, CURLOPT_POSTFIELDS, $postData);
	curl_setopt($urlRs, CURLOPT_TIMEOUT, 10); 		 // 读取URL的超时时间 10s
	curl_setopt($urlRs, CURLOPT_CONNECTTIMEOUT, 10); //连接超时时间 10s
	//判断是否是HTTPS请求
	if(strlen($requestUrl) > 5 && strtolower(substr($requestUrl, 0, 5)) == "https" ){
		curl_setopt($urlRs, CURLOPT_SSL_VERIFYPEER, false);
		curl_setopt($urlRs, CURLOPT_SSL_VERIFYHOST, 0);
	}
	//发送消息,获取响应
	$reponse = curl_exec($urlRs);
	//关闭连接
	curl_close($urlRs);
	return $reponse;
}

为了开发方便PHP封装简单易用请求接口类curl封装类支持多文件上传,支持json数据传输,直接实例化类调用方法传参即可,省掉了频繁写curl相关参数配置的麻烦,具体看下边示例。

demo.php文件:

include 'log.php';
include 'PHPcurl.php';
// 调用示例:
//* 一、GET请求:
$url = 'http://test.com/plug/phpcurl/test.php?id=1&name=越加网';
$request = new PHPcurl();
$result = $request->httpGet($url);
print_r($result);//exit;
//*/
// 二、POST请求:
$url = 'http://test.com/plug/phpcurl/test.php';
$params['id'] = 1;
$params['name'] = '越加网';
$files['key'] = 'headimg';
$files['data'] = array('type'=>'image/jpeg','path'=>'E:/www/test/filetest/getfile/1.jpg');
/* 如果是多文件时$files['data']为多维数组,如:
 $files['data'][0] = array('type'=>'image/jpeg','path'=>'E:/www/test/filetest/getfile/1.jpg'); // 文件一
 $files['data'][1] = array('type'=>'image/jpeg','path'=>'E:/www/test/filetest/getfile/2.jpg'); // 文件二
 */
$request = new PHPcurl();
$result = $request->httpPost($url,$params,false,$files);
print_r($result);

test.php文件(这里上传的文件不做处理只打印接收记录,文件上传接收源码请查看上几篇文章或者在站内搜索“文件上传”关键字查看相关文章):

include 'log.php';
loger($_REQUEST);
loger($_FILES);
echo json_encode(array('code'=>10000,'msg'=>'成功'));

PHPcurl.php类文件:

/**
 * Notes:PHP Curl 请求工具类
 * User: ZHL
 * Date: 2020/5/26
 */
class PHPcurl{

    //读取URL的超时时间 10s
    private $timeout = 10;

    //连接超时时间 10s
    private $connectTimeout = 10;

    /**
	 * Notes:GET请求
	 */
    public function httpGet($requestUrl){
        $urlRs = curl_init();
        curl_setopt($urlRs, CURLOPT_URL, $requestUrl);
        curl_setopt($urlRs, CURLOPT_FAILONERROR, false);
        curl_setopt($urlRs, CURLOPT_RETURNTRANSFER, true);
        if ($this->timeout) {
            curl_setopt($urlRs, CURLOPT_TIMEOUT, $this->timeout);
        }
        if ($this->connectTimeout) {
            curl_setopt($urlRs, CURLOPT_CONNECTTIMEOUT, $this->connectTimeout);
        }
        //判断是否是HTTPS请求
        if(strlen($requestUrl) > 5 && strtolower(substr($requestUrl, 0, 5)) == "https" ){
            curl_setopt($urlRs, CURLOPT_SSL_VERIFYPEER, false);
            curl_setopt($urlRs, CURLOPT_SSL_VERIFYHOST, 0);
        }
        //发送消息,获取响应
        $response = curl_exec($urlRs);
        //关闭连接
        curl_close($urlRs);
        return $response;
    }

    /**
	 * Notes:POST请求
	 */
    public function httpPost($requestUrl, $postData, $jsonType=false, $files=array()){
		// 有文件
		if(isset($files['key']) && isset($files['data']) && $files['key'] && !empty($files['data'])){
			if(isset($postData[$files['key']])){
				return json_encode(array('code'=>40000,'msg'=>'文件key在其他参数中已被占用'));
			}
			$key = $files['key'];
			$data = $files['data'];
			// 单文件
			if(isset($data['type']) && isset($data['path']) && $data['type'] && $data['path']){
				if(version_compare(phpversion(),'5.5.0') >= 0 && class_exists('CURLFile')){
					$postData[$key] = new CURLFile($data['path'],$data['type']);
				}else{
					$postData[$key] = '@'.$data['path'];//加@符号curl就会把它当成是文件上传处理
				}
			}else{ // 多文件
				foreach($data as $k=>$v){
					if(isset($v['path']) && isset($v['type']) && $v['path'] && $v['type']){
						if(version_compare(phpversion(),'5.5.0') >= 0 && class_exists('CURLFile')){
							$postData[$key.$k] = new CURLFile($v['path'],$v['type']);
						}else{
							$postData[$key.$k] = '@'.$v['path'];
						}
					}
				}
			}
		}
		
		//print_r($postData);exit;
        $urlRs = curl_init();
		// 如果是json格式POST请求
		if($jsonType){
			$headers = array(
                        "Content-type:application/json;charset='utf-8'",
                        "Accept: application/json",
                        "Cache-Control: no-cache",
                        "Pragma: no-cache");
			curl_setopt($urlRs, CURLOPT_HTTPHEADER, $headers);
		}
        curl_setopt($urlRs, CURLOPT_URL, $requestUrl);
        curl_setopt($urlRs, CURLOPT_FAILONERROR, false);
        curl_setopt($urlRs, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($urlRs, CURLOPT_POST, true);
        curl_setopt($urlRs, CURLOPT_POSTFIELDS, $postData);
        if ($this->timeout) {
            curl_setopt($urlRs, CURLOPT_TIMEOUT, $this->timeout);
        }
        if ($this->connectTimeout) {
            curl_setopt($urlRs, CURLOPT_CONNECTTIMEOUT, $this->connectTimeout);
        }
        //判断是否是HTTPS请求
        if(strlen($requestUrl) > 5 && strtolower(substr($requestUrl, 0, 5)) == "https" ){
            curl_setopt($urlRs, CURLOPT_SSL_VERIFYPEER, false);
            curl_setopt($urlRs, CURLOPT_SSL_VERIFYHOST, 0);
        }
        //发送消息,获取响应
        $reponse = curl_exec($urlRs);
        //关闭连接
        curl_close($urlRs);
        return $reponse;
    }
}

log.php文件源码请查看之前的PHP错误排查生成日志文件的文章,连接:https://www.yj521.com/article/39.html

调用demo.php文件后生成的日志数据如下

GET提交接收数据:

[2020-05-27 11:11:01][DEBUG]=>Array
(
    [id] => 1
    [name] => 越加网
)
// 文件参数
[2020-05-27 11:11:01][DEBUG]=>Array
(
)

POST提交接收数据-附带单文件上传:

[2020-05-27 11:12:46][DEBUG]=>Array
(
    [id] => 1
    [name] => 越加网
)
[2020-05-27 11:12:46][DEBUG]=>Array
(
    [headimg] => Array
        (
            [name] => 1.jpg
            [type] => image/jpeg
            [tmp_name] => C:\Windows\Temp\phpD080.tmp
            [error] => 0
            [size] => 121492
        )

)

POST提交接收数据-附带多文件上传:

[2020-05-27 11:13:29][DEBUG]=>Array
(
    [id] => 1
    [name] => 越加网
)
[2020-05-27 11:13:29][DEBUG]=>Array
(
    [headimg0] => Array
        (
            [name] => 1.jpg
            [type] => image/jpeg
            [tmp_name] => C:\Windows\Temp\php7ACA.tmp
            [error] => 0
            [size] => 121492
        )
    [headimg1] => Array
        (
            [name] => 2.jpg
            [type] => image/jpeg
            [tmp_name] => C:\Windows\Temp\php7ACB.tmp
            [error] => 0
            [size] => 1954
        )
)

源码下载链接:https://pan.baidu.com/s/1q5etgUKY4vSQ14aa2ymZlg

提取码:3lj3

压缩包解压密码:www.yj521.com

压缩包内容:

phpcurl.class

yj521.com.txt:使用说明文档

越加网:越加网快捷方式(给个支持^_^)

附:常用CURL选项说明

CURLOPT_AUTOREFERER

 当根据Location:重定向时,自动设置header中的Referer:信息。

CURLOPT_BINARYTRANSFER

 在启用CURLOPT_RETURNTRANSFER的时候,返回原生的(Raw)输出。 

CURLOPT_COOKIESESSION

 启用时curl会仅仅传递一个session cookie,忽略其他的cookie,默认状况下cURL会将所有的cookie返回给服务端。session cookie是指那些用来判断服务器端的session是否有效而存在的cookie。 

CURLOPT_CRLF

 启用时将Unix的换行符转换成回车换行符。 

CURLOPT_DNS_USE_GLOBAL_CACHE

 启用时会启用一个全局的DNS缓存,此项为线程安全的,并且默认启用。 

CURLOPT_FAILONERROR

 显示HTTP状态码,默认行为是忽略编号小于等于400的HTTP信息。 

CURLOPT_FILETIME

 启用时会尝试修改远程文档中的信息。结果信息会通过 curl_getinfo()函数的CURLINFO_FILETIME选项返回。curl_getinfo(). 

CURLOPT_FOLLOWLOCATION

 启用时会将服务器服务器返回的”Location: “放在header中递归的返回给服务器,使用CURLOPT_MAXREDIRS可以限定递归返回的数量。 

CURLOPT_FORBID_REUSE

 在完成交互以后强迫断开连接,不能重用。 

CURLOPT_FRESH_CONNECT

 强制获取一个新的连接,替代缓存中的连接。 

CURLOPT_FTP_USE_EPRT

 启用时当FTP下载时,使用EPRT (或 LPRT)命令。设置为FALSE时禁用EPRT和LPRT,使用PORT命令 only. 

CURLOPT_FTP_USE_EPSV

 启用时,在FTP传输过程中回复到PASV模式前首先尝试EPSV命令。设置为FALSE时禁用EPSV命令。 

CURLOPT_FTPAPPEND

 启用时追加写入文件而不是覆盖它。 

CURLOPT_FTPASCII

 CURLOPT_TRANSFERTEXT的别名。 

CURLOPT_FTPLISTONLY

 启用时只列出FTP目录的名字。 

CURLOPT_HEADER

 启用时会将头文件的信息作为数据流输出。 

CURLINFO_HEADER_OUT

 启用时追踪句柄的请求字符串。

 从 PHP 5.1.3 开始可用。CURLINFO_前缀是故意的(intentional)。

CURLOPT_HTTPGET

 启用时会设置HTTP的method为GET,因为GET是默认是,所以只在被修改的情况下使用。 

CURLOPT_HTTPPROXYTUNNEL

 启用时会通过HTTP代理来传输。 

CURLOPT_MUTE

 启用时将cURL函数中所有修改过的参数恢复默认值。 

CURLOPT_NETRC

 在连接建立以后,访问~/.netrc文件获取用户名和密码信息连接远程站点。 

CURLOPT_NOBODY

 启用时将不对HTML中的BODY部分进行输出。 

CURLOPT_NOPROGRESS

 启用时关闭curl传输的进度条,此项的默认设置为启用。

 PHP自动地设置这个选项为TRUE,这个选项仅仅应当在以调试为目的时被改变。

CURLOPT_NOSIGNAL

 启用时忽略所有的curl传递给php进行的信号。在SAPI多线程传输时此项被默认启用。

 cURL 7.10时被加入。

CURLOPT_POST

 启用时会发送一个常规的POST请求,类型为:application/x-www-form-urlencoded,就像表单提交的一样。 

CURLOPT_PUT

 启用时允许HTTP发送文件,必须同时设置CURLOPT_INFILE和CURLOPT_INFILESIZE。 

CURLOPT_RETURNTRANSFER

 将 curl_exec()获取的信息以文件流的形式返回,而不是直接输出。 

CURLOPT_SSL_VERIFYPEER

 禁用后cURL将终止从服务端进行验证。使用CURLOPT_CAINFO选项设置证书使用CURLOPT_CAPATH选项设置证书目录 如果CURLOPT_SSL_VERIFYPEER(默认值为2)被启用,CURLOPT_SSL_VERIFYHOST需要被设置成TRUE否则设置为FALSE。

 自cURL 7.10开始默认为TRUE。从cURL 7.10开始默认绑定安装。

CURLOPT_TRANSFERTEXT

 启用后对FTP传输使用ASCII模式。对于LDAP,它检索纯文本信息而非HTML。在Windows系统上,系统不会把STDOUT设置成binary模式。 

CURLOPT_UNRESTRICTED_AUTH

 在使用CURLOPT_FOLLOWLOCATION产生的header中的多个locations中持续追加用户名和密码信息,即使域名已发生改变。 

CURLOPT_UPLOAD

 启用后允许文件上传。 

CURLOPT_VERBOSE

 启用时会汇报所有的信息,存放在STDERR或指定的CURLOPT_STDERR中。


上一篇:PHP判断是手机移动端还是电脑PC端方法下一篇:window10激活工具office激活KMSAutov1.4绿色中文版原版
赞(7) 踩(0)
您说多少就多少,您的支持是我最大的动力
赏金
微 信
赏金
支付宝
本文连接: https://www.yj521.com/article/62.html
版权声明: 本文为原创文章,版权归《越加网》所有,分享转载请注明出处!