微信网页授权是服务号才有的高级功能,开发者可以通过授权后获取用户的基本信息;在此之前,想要获取消息信息只能在用户和公众号交互时根据openid获取用户信息;而微信网页授权可在不需要消息交互,也不需要关注的情况下获取用户的基本信息。
微信网页授权时通过OAuth2.0完成的,整个过程分为三步:
- 用户授权,获取code;
- 根据code获取access_token【可通过refresh_token刷新获取较长有效期】
- 通过access_token和openid获取用户信息
对微信网页授权过程做了简单封装:
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
|
<?php
/**
* 微信授权相关接口
*/
class Wechat {
//高级功能-》开发者模式-》获取
private $app_id = 'xxx' ;
private $app_secret = 'xxxxxxx' ;
/**
* 获取微信授权链接
*
* @param string $redirect_uri 跳转地址
* @param mixed $state 参数
*/
public function get_authorize_url( $redirect_uri = '' , $state = '' )
{
$redirect_uri = urlencode( $redirect_uri );
return " https://open.weixin.qq.com/connect/oauth2/authorize?appid= {$this->app_id}&redirect_uri={$redirect_uri}&response_type=code&scope=snsapi_userinfo&state={$state}#wechat_redirect" ;
}
/**
* 获取授权token
*
* @param string $code 通过get_authorize_url获取到的code
*/
public function get_access_token( $app_id = '' , $app_secret = '' , $code = '' )
{
$token_url = " https://api.weixin.qq.com/sns/oauth2/access_token?appid= {$this->app_id}&secret={$this->app_secret}&code={$code}&grant_type=authorization_code" ;
$token_data = $this ->http( $token_url );
if ( $token_data [0] == 200)
{
return json_decode( $token_data [1], TRUE);
}
return FALSE;
}
/**
* 获取授权后的微信用户信息
*
* @param string $access_token
* @param string $open_id
*/
public function get_user_info( $access_token = '' , $open_id = '' )
{
if ( $access_token && $open_id )
{
$info_url = " https://api.weixin.qq.com/sns/userinfo?access_token= {$access_token}&openid={$open_id}&lang=zh_CN" ;
$info_data = $this ->http( $info_url );
if ( $info_data [0] == 200)
{
return json_decode( $info_data [1], TRUE);
}
}
return FALSE;
}
public function http( $url , $method , $postfields = null, $headers = array (), $debug = false)
{
$ci = curl_init();
/* Curl settings */
curl_setopt( $ci , CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_1);
curl_setopt( $ci , CURLOPT_CONNECTTIMEOUT, 30);
curl_setopt( $ci , CURLOPT_TIMEOUT, 30);
curl_setopt( $ci , CURLOPT_RETURNTRANSFER, true);
switch ( $method ) {
case 'POST' :
curl_setopt( $ci , CURLOPT_POST, true);
if (! empty ( $postfields )) {
curl_setopt( $ci , CURLOPT_POSTFIELDS, $postfields );
$this ->postdata = $postfields ;
}
break ;
}
curl_setopt( $ci , CURLOPT_URL, $url );
curl_setopt( $ci , CURLOPT_HTTPHEADER, $headers );
curl_setopt( $ci , CURLINFO_HEADER_OUT, true);
$response = curl_exec( $ci );
$http_code = curl_getinfo( $ci , CURLINFO_HTTP_CODE);
if ( $debug ) {
echo "=====post data======\r\n" ;
var_dump( $postfields );
echo '=====info=====' . "\r\n" ;
print_r(curl_getinfo( $ci ));
echo '=====$response=====' . "\r\n" ;
print_r( $response );
}
curl_close( $ci );
return array ( $http_code , $response );
}
}
|
以上就是本文的全部内容,希望对大家的学习有所帮助。