SpringBoot中获取微信用户信息从未如此简单

前言
不知道你是否参加过拼多多上邀请微信好友砍价功能 , 这个功能实现首先需要考虑的就是获取微信用户的信息 。获取用户信息就是获取公众号下微信用户的信息 , 今天我就来讲讲如何从公众号下获取微信用户信息 。
需要声明一点的是获取微信公众号下的用户信息的权限是服务号才有 , 个人订阅号是没有该权限的 。
获取公众号用户信息实战
第一步需要先申请接口测试号并进行网页授权设置
访问如下链接进行接口测试号申请 。
https://developers.weixin.qq.com/doc/offiaccount/Basic_Information/Requesting_an_API_Test_Account.html选择接口测试号申请 , 如下图所示:

SpringBoot中获取微信用户信息从未如此简单

文章插图
 

SpringBoot中获取微信用户信息从未如此简单

文章插图
 
点击登录进行扫码登录 , 如下图所示:
SpringBoot中获取微信用户信息从未如此简单

文章插图
 
登录后如下图所示:
SpringBoot中获取微信用户信息从未如此简单

文章插图
 
在下面的的网页账号一栏添加网页授权的IP或者域名 。
SpringBoot中获取微信用户信息从未如此简单

文章插图
 

SpringBoot中获取微信用户信息从未如此简单

文章插图
 
为了方便测试我这里设置成了回环地址 , 最好设置成具体的 IP 地址或者域名信息 。域名和 IP 地址不要添加http或者https 。这里 IP 和域名可以是内网地址 。
到这里网页授权设置完毕!
第二步是下载微信web开发者工具 , 可以在PC 进行测试 。
https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Web_Developer_Tools.html
SpringBoot中获取微信用户信息从未如此简单

文章插图
 
傻瓜式一步一步安装即可 。
第三步 看微信操作教程并完成代码实现
接下来就是代码部分编写了 , 在开发前首先需要看一下获取微信公众号用户信息的教程:
通过访问:https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_webpage_authorization.html。获取微信用户信息具体操作有如下4步 。
SpringBoot中获取微信用户信息从未如此简单

文章插图
 
第一步:用户同意授权 , 获取code
代码的操作就是拼接引导用户进行微信授权地址 , 然后重定向到微信服务 , 微信服务在根据重定向的 URL 地址并携带 code 重定向到我们的服务器 。这一步需要配置有公众号 appid 和 redirect_uri。
需要注意的是重定向的地址需要 encode 以下 , 具体操作如下面代码所示:
String url = URLEncoder.encode(request.getRequestURL().toString());具体地址如下图所示:红色框位置需要改为我们公众号 appid 和 redirect_uri 信息 , 其他的内容不用改动 。
SpringBoot中获取微信用户信息从未如此简单

文章插图
 
程序重定向该地址后会让用户进行授权 , 如下图所示:
SpringBoot中获取微信用户信息从未如此简单

文章插图
 
用户点击同意后 , 微信服务会根据重定向地址重定向回我们的服务中并携带code 。
第二步就是根据 code 获取网页授权 access_token 和 openid 。
调用如下面所示微信 API  , 红色框 code 替换成获取的 code , 其他内容不用做任何改动 。
SpringBoot中获取微信用户信息从未如此简单

文章插图
 
第三步:刷新access_token(如果需要)
access_token有效期是7200s , 当access_token超时后 , 可以使用refresh_token进行刷新 , refresh_token有效期为30天 , 当refresh_token失效之后 , 需要用户重新授权 。这步可做可不做 , 我们这里就绕开这步 。
第四步:拉取用户信息(需scope为 snsapi_userinfo)
关于网页授权的两种scope的区别说明
1、以snsapi_base为scope发起的网页授权 , 是用来获取进入页面的用户的openid的 , 并且是静默授权并自动跳转到回调页的 。用户感知的就是直接进入了回调页(往往是业务页面)
2、以snsapi_userinfo为scope发起的网页授权 , 是用来获取用户的基本信息的 。但这种授权需要用户手动同意 , 并且由于用户同意过 , 所以无须关注 , 就可在授权后获取该用户的基本信息 。


推荐阅读