KfwOpenapi.php
1.96 KB
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
<?php
/**
* 快服务开放平台接口调用工具类
* 详情:签名,接口调用
* 版本:1.0
* 日期:2016-09-10
* 说明:
* 以下代码只是为了方便对接商户测试而提供的样例代码,对接商户可以根据自己的需求,按照技术文档编写,代码仅供参考。
*/
class KfwOpenapi{
/**
* 快服务开发者app_key
*/
private $app_key;
/**
* 快服务开发者app_secret
*/
private $app_secret;
/**
* api url地址
*/
private $url;
/**
* 用户授权 token
*/
private $access_token;
/**
* 数据格式
*/
private $format = "json";
/**
* 商户ID
*/
private $openid ;
/**
* http request timeout;
*/
private $httpTimeout = 5;
/**
* 签名生成signature
*/
public function getSign($data,$app_secret){
//1.升序排序
ksort($data);
//2.字符串拼接
$args = "";
foreach ($data as $key => $value) {
$args.=$key."=".$value."&";
}
$args=rtrim($args, "&");
$args=$args."&key=".$app_secret;
//var_dump($args);die;
//3.MD5签名,转为大写
$sign = strtoupper(md5($args));
return $sign;
}
/**
* 发送请求,POST
* @param $url 指定URL完整路径地址
* @param $data 请求的数据
*/
public function requestWithPost($url, $data){
// json
$headers = array(
'Content-Type: application/json',
);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,0);
curl_setopt($ch, CURLOPT_POST,1);
curl_setopt($ch, CURLOPT_POSTFIELDS,$data);
$data = curl_exec($ch);
curl_close($ch);
return $data;
}
}