网页授权
如果公众号服务端需要获得用户的信息,需要走标准的OAuth2流程。整个OAuth2协议比较复杂,本文只是简单的叙述一下流程。
以ArtisanCloud前后端分离的服务为例:
- 前端域名 : https://www.artisan-cloud.com
- 服务端域名 : https://api.artisan-cloud.com
会发生如下步骤:
- 前端发起跳转请求,用户根据scope不同可能需要允许应用获取个人信息。
https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx4371973ec8f9fa2a&redirect_uri=https://www.artisan-cloud.com&response_type=code&scope=snsapi_userinfo&state=123#wechat_redirect
- 用户同意授权,微信会重定向回
https://www.artisan-cloud.com?code=xxxxx
。 - 前端获取code参数,把参数提交给ArtisanCloud服务端。
- 服务端根据code,换取网页授权access_token,这一步同时会得到openid,到这一步登录流程基本算是完成。
- (可选)如果需要进一步获取用户昵称头像,需要继续使用上一步的access_token获取用户信息。
在前后端架构分离的情况下,这个和小程序那边是有点相似,获取code这一步都是在前端完整,获取到code才会提交给服务端进行用户信息验证。
整个OAuth2,服务端实际上只需要用到下面几个接口:
code获取用户基础信息
OfficialAccountApp.OAuth.UserFromCode("[code]")
token获取用户信息
OfficialAccountApp.OAuth.UserFromToken("[token]")
以下是群里的用户总结使用的场景,可以参考:
snsapi_base,TokenFromCode 可以获取到 token 和 openid,再通过公众号的【用户信息】接口去获取 unionid (需要已关注公众号,否则为空)
snsapi_userinfo,code 可直接换取拿到 openId, unionId, token,需要头像昵称,若通过 accessToken 去获取更详细的用户信息(UserFromToken)。
go
// 拉取用户信息(需scope为snsapi userinfo)
tokenResponse, err := officialAccountApp.OAuth.TokenFromCode(authCode)
if err != nil {
return
}
accessToken := (*tokenResponse)["access_token"].(string)
unionID := (*tokenResponse) ["unionid"].(string)
openID := (*tokenResponse) ["openid"].(string)
user,_ := officialAccountApp.0Auth.UserFromToken(accessToken,openID)