问题描述
使用场景
-
复现场景:
微信开放平台·微信公众号链接:微信开发平台- 按照文档说明通过 code 获取 access_token
- 检验授权凭证(access_token)是否有效
- 获取用户个人信息(此处报错)
-
在调用用户个人信息时,报错【“errcode”:48001"errmsg":“api unauthorized…”】
-
以上步骤页面关键字搜索可找到接口路径
解决方案
-
根据接口返回的说明我们大概能知道是接口访问权限出了问题,但是还是有些一头雾水不知从哪下手,网友的力量还是挺大的,经过几篇文章可得知,其实是用户授权这一步接口出了问题。
授权获取code接口:https://open.weixin.qq.com/connect/oauth2/authorize?appid={0}&redirect_uri={1}&response_type=code&scope={2}&state=ok#wechat_redirect -
按照微信的OAuth2流程中,先用户授权获取code才能得到access_token,在以上我们的场景下并没有去通知用户进行授权,获取code的时候有一个scope的字段入参,字段有两个值类型snsapi_base和snsapi_userinfo
-
区别:
【snsapi_base】:不需要用户点同意,直接跳转到授权后的页面,只能用于获取openid,不能获取用户基本信息
【snsapi_userinfo】:会征求用户同意,授权后,可以获取用户基本信息 -
所以我们在获取code的是时候是用snsapi_base换来的code,在调用获取用户信息接口时是不被允许的,所以使用snsapi_userinfo类型入参换取的code,接下来获取access_token就可以访问用户信息接口了。
就先说到这
\color{#008B8B}{ 就先说到这}
就先说到这
在下
A
p
o
l
l
o
\color{#008B8B}{在下Apollo}
在下Apollo
一个爱分享
J
a
v
a
、生活的小人物,
\color{#008B8B}{一个爱分享Java、生活的小人物,}
一个爱分享Java、生活的小人物,
咱们来日方长,有缘江湖再见,告辞!
\color{#008B8B}{咱们来日方长,有缘江湖再见,告辞!}
咱们来日方长,有缘江湖再见,告辞!