公众号开发时会遇到讨厌的access_token用着用着就发懵了,access_token是公众号的全局唯一接口调用凭据,公众号调用各接口时都需要使用access_token。基本上可以分为两种access_token。
一.网页授权access_token
可以通过https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code 接口来获取
二.基础/普通access_token
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET接口来获取
两种access_token的区别
- 有效期:两者有效时间都是7200s。
- 使用范围:通过网页授权获得的access_token,只能获取到对应的微信用户信息,与微信用户是一对一关系;而普通的access_token在有效期内可以使用,可以获取所有用户信息。
- 调用的 次数限制:普通access_token每天获取最多次数为2000次,而网页授权的access_token获取次数没有限制。
微信用户信息获取方法:可以基础/普通access_token 来获取关注公众号的微信号的所有信息,包括唯一标识的union_id,拿到微信用户access_token 和 open_id 获取信息(
https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN)接口* subscribe 用户是否订阅该公众号标识,值为0时,代表此用户没有关注该公众号,拉取不到其余信息。
openid 用户的标识,对当前公众号唯一
nickname 用户的昵称
sex 用户的性别,值为1时是男性,值为2时是女性,值为0时是未知
city 用户所在城市
country 用户所在国家
province 用户所在省份
language 用户的语言,简体中文为zh_CN
headimgurl 用户头像,最后一个数值代表正方形头像大小(有0、46、64、96、132数值可选,0代表640*640正方形头像),用户没有头像时该项为空。若用户更换头像,原有头像URL将失效。
subscribe_time 用户关注时间,为时间戳。如果用户曾多次关注,则取最后关注时间
unionid 只有在用户将公众号绑定到微信开放平台帐号后,才会出现该字段。
remark 公众号运营者对粉丝的备注,公众号运营者可在微信公众平台用户管理界面对粉丝添加备注
groupid 用户所在的分组ID(兼容旧的用户分组接口)
tagid_list 用户被打上的标签ID列表
获取open_id:
code=
https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect 这个接口中有个参数scope 默认有2个值snsapi_base和snsapi_userinfo,这个接口会根据scope 来生成不同的code并且获取不同作用的access_token ,不管scope传什么值都能在得到对应access_token的同时得到open_id,
通过接口$url=https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code
//初始化curl
c
h
=
c
u
r
l
i
n
i
t
(
)
;
/
/
设
置
超
时
c
u
r
l
s
e
t
o
p
t
(
ch = curl_init(); //设置超时 curl_setopt(
ch=curlinit();//设置超时curlsetopt(ch, CURLOPT_TIMEOUT,
t
h
i
s
−
>
c
u
r
l
t
i
m
e
o
u
t
)
;
c
u
r
l
s
e
t
o
p
t
(
this->curl_timeout); curl_setopt(
this−>curltimeout);curlsetopt(ch, CURLOPT_URL,
u
r
l
)
;
c
u
r
l
s
e
t
o
p
t
(
url); curl_setopt(
url);curlsetopt(ch, CURLOPT_SSL_VERIFYPEER,FALSE);
curl_setopt(
c
h
,
C
U
R
L
O
P
T
S
S
L
V
E
R
I
F
Y
H
O
S
T
,
F
A
L
S
E
)
;
c
u
r
l
s
e
t
o
p
t
(
ch, CURLOPT_SSL_VERIFYHOST,FALSE); curl_setopt(
ch,CURLOPTSSLVERIFYHOST,FALSE);curlsetopt(ch, CURLOPT_HEADER, FALSE);
curl_setopt(KaTeX parse error: Expected 'EOF', got '&' at position 87: … "0.0.0.0" &̲& WxPayConfig::…ch,CURLOPT_PROXY, WxPayConfig::CURL_PROXY_HOST);
curl_setopt($ch,CURLOPT_PROXYPORT, WxPayConfig::CURL_PROXY_PORT);
}
//运行curl,结果以jason形式返回
r
e
s
=
c
u
r
l
e
x
e
c
(
res = curl_exec(
res=curlexec(ch);
curl_close($ch);
d
a
t
a
=
j
s
o
n
d
e
c
o
d
e
(
data = json_decode(
data=jsondecode(res,true);
//取出openid
获取 access_token 和 open_idopen_id=data['access_token '];