微信开发交流群:148540125
系列文章参考地址 极速开发微信公众号
欢迎留言、转发、打赏
项目源码参考地址 点我点我–欢迎Start
前几篇文章已讲完如何导入项目,如何启动配置项目,如何成为开发者,重源码分析消息是如何交互、如何自定义菜单(如果以上不是很清楚可以看这里 极速开发微信公众号。这篇文章就来聊聊授权获取用户信息
一、什么是OAuth2.0
这里整理了一篇文章 理解OAuth2.0
二、微信公众平台OAuth2.0授权详细步骤
- 用户关注微信公众账号(现在也可以不关注)。
- 微信公众账号提供用户请求授权页面URL。
- 用户点击授权页面URL,将向服务器发起请求
- 服务器询问用户是否同意授权给微信公众账号(scope为snsapi_base时无此步骤)
- 用户同意(scope为snsapi_base时无此步骤,不弹出授权页面,直接跳转,只能获取用户openid)
- 服务器将code参数通过回调传给微信公众账号
- 微信公众账号获得code参数
- 微信公众账号通过code参数向服务器请求Access Token
- 服务器返回Access Token和OpenID给微信公众账号
- 微信公众账号通过Access Token向服务器请求用户信息(scope为snsapi_base时无此步骤)
- 服务器将用户信息回送给微信公众账号(scope为snsapi_base时无此步骤)
#三、配置授权回调页面域名
沙盒号(测试号)回调地址支持域名和ip,正式公众号回调地址只支持域名并且域名需使用字母、数字及“-”的组合,须通过ICP备案的验证,不支持端口号及短链。
测试号:找到 网页授权获取用户基本信息>点击修改>设置域名
服务号:找到 开发>接口权限>网页授权获取用户基本信息>>点击修改>设置域名
详细介绍参考官方文档
四、用户授权并获取code ,使用code换取access_token 并使用access_token获取用户信息
授权访问的URL:
具体封装实现可以查看com.jfinal.weixin.sdk.api.SnsAccessTokenApi.getAuthorizeURL(....)
方法
之前博客使用Servlet 也写了一个简单的授权参考地址
五、使用封装的接口实现授权获取用户信息
封装之后使用就非常的简单,SnsAccessTokenApi.getAuthorizeURL(....)
- 第一个参数为
appId
- 第二个参数为授权后回调的地址
http://域名/oauth
- 第三个参数为
state
重定向后会带上state参数,开发者可以填写a-zA-Z0-9的参数值,最多128字节 第四个参数 应用授权作用域,简单讲是否弹出授权页面 。true
为不弹出授权页面
应用授权作用域,snsapi_base (不弹出授权页面,直接跳转,只能获取用户openid),snsapi_userinfo (弹出授权页面,可通过openid拿到昵称、性别、所在地。并且,即使在未关注的情况下,只要用户授权,也能获取其信息)
具体实现代码如下
oauth Controller 具体实现步骤如下:
- 当用户同意授权,获取code以及state
如果code不为null,就可以通过code换取网页授权access_token
1234567{"access_token":"ACCESS_TOKEN","expires_in":7200,"refresh_token":"REFRESH_TOKEN","openid":"OPENID","scope":"SCOPE"}拉取用户信息(需scope为 snsapi_userinfo)
|
|
- 获取用户信息之后可以根据上面的state跳转到不同的页面
具体实现代码如下
以上是授权获取用户信息的全过程。
欢迎留言、转发、打赏
项目源码参考地址 点我点我–欢迎Start