本文实例讲述了PHP封装请求类。分享给大家供大家参考,具体如下:
1.源码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
<?php namespace app\common\components; use Yii; use app\common\services\BaseService; class HttpClient extends BaseService{ private static $headers = []; private static $cookie = null; public static function get( $url , $param =[]) { return self::curl( $url , $param , "get" ); } public static function post( $url , $param , $extra = [] ) { return self::curl( $url , $param , "post" ); } protected static function curl( $url , $param , $method = 'post' ) { $calculate_time1 = microtime(true); // 初始华 $curl = curl_init(); // 设置url curl_setopt( $curl , CURLOPT_URL, $url ); // 设置为0表示不返回HTTP头部信息 curl_setopt( $curl , CURLOPT_HEADER, 0); // 设置为1返回将curl_exec()获取的信息以字符串返回,而不是直接输出 设置为0返回true/false curl_setopt( $curl , CURLOPT_RETURNTRANSFER, 1); // TRUE 将在安全传输时输出 SSL 证书信息到 STDERR。 curl_setopt( $curl , CURLOPT_CERTINFO , true); curl_setopt( $curl , CURLOPT_SSL_VERIFYPEER, false); // FALSE 禁止 cURL 验证对等证书 // 交换证书可以在 CURLOPT_CAINFO 选项中设置,CURLOPT_CAPATH中设置证书目录。 curl_setopt( $curl , CURLOPT_FOLLOWLOCATION, 1); if ( isset( Yii:: $app ->params[ 'curl' ] ) && isset(Yii:: $app ->params[ 'curl' ][ 'timeout' ]) ){ curl_setopt( $curl , CURLOPT_TIMEOUT, Yii:: $app ->params[ 'curl' ][ 'timeout' ]); } else { curl_setopt( $curl , CURLOPT_TIMEOUT, 5); } // array_key_exists — 检查数组里是否有指定的键名或索引 // CURLOPT_USERAGENT在HTTP请求中包含一个"User-Agent: "头的字符串 if ( array_key_exists ( "HTTP_USER_AGENT" , $_SERVER )){ curl_setopt( $curl , CURLOPT_USERAGENT, $_SERVER [ 'HTTP_USER_AGENT' ]); } // CURLOPT_HTTPHEADER设置 HTTP 头字段的数组。格式: array('Content-type: text/plain', 'Content-length: 100') if (! empty (self:: $headers )){ $headerArr = []; foreach ( self:: $headers as $n => $v ) { $headerArr [] = $n . ': ' . $v ; } curl_setopt ( $curl , CURLOPT_HTTPHEADER , $headerArr ); //构造IP } // CURLOPT_COOKIE设定 HTTP 请求中"Cookie: "部分的内容。多个 cookie 用分号分隔,分号后带一个空格(例如, "fruit=apple; colour=red")。 if ( self:: $cookie ){ curl_setopt( $curl , CURLOPT_COOKIE, self:: $cookie ); } // post处理 :TRUE 时会发送 POST 请求,类型为:application/x-www-form-urlencoded,是 HTML 表单提交时最常见的一种。 if ( $method == 'post' ) { curl_setopt( $curl , CURLOPT_POST, TRUE); // 如果为数组就变成字符串 if ( is_array ( $param )){ $param = http_build_query( $param ); } // 全部数据使用HTTP协议中的 "POST" 操作来发送。 要发送文件,在文件名前面加上@前缀并使用完整路径。 curl_setopt( $curl , CURLOPT_POSTFIELDS, $param ); } else { //get请求 curl_setopt( $curl , CURLOPT_POST, FALSE); } // 执行输出 $info = curl_exec( $curl ); //log:返回最后一次的错误代码 $_errno = curl_errno( $curl ); $_error = '' ; if ( $_errno ) { // 返回当前会话最后一次错误的字符串 $_error = curl_error( $curl ); } curl_close( $curl ); // 花费的时间 $calculate_time_span = microtime(true) - $calculate_time1 ; $log = \Yii:: $app ->getRuntimePath().DIRECTORY_SEPARATOR. 'curl.log' ; // int file_put_contents ( string $filename , mixed $data [, int $flags = 0 [, resource $context ]] ) file_put_contents ( $log , date ( 'Y-m-d H:i:s' ). " [ time:{$calculate_time_span} ] url: {$url} \nmethod: {$method} \ndata: " .json_encode( $param ). " \nresult: {$info} \nerrorno: {$_errno} error: {$_error} \n" ,FILE_APPEND); if ( $_error ){ return self::_err( $_error ); } return $info ; } public static function setHeader( $header ){ self:: $headers = $header ; } public static function setCookie( $cookie ){ self:: $cookie = $cookie ; } } |
2.分析
microtime()
函数返回当前 Unix 时间戳的微秒数。
当设置为 TRUE 时,规定函数应该返回一个浮点数,否则返回一个字符串。默认为 FALSE。
详细的各种分析写在代码里面了
3.总结
总结就是get与post差不多(初始化执行关闭) 选项也差不多 就是在方式上面会有些差别!
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。
原文链接:https://blog.csdn.net/fujian9544/article/details/90578593