1 微信公众账号提供用户请求授权页面URL。
2 用户点击授权页面URL,将向服务器发起请求
3 服务器询问用户是否同意授权给微信公众账号(scope为snsapi_base时无此步骤)
4 用户同意(scope为snsapi_base时无此步骤,不弹出授权页面,直接跳转,只能获取用户openid)
5 服务器将code参数通过回调传给微信公众账号
6 微信公众账号获得code参数
7 微信公众账号通过code参数向服务器请求Access Token
8 服务器返回Access Token和OpenID给微信公众账号
9 微信公众账号通过Access Token向服务器请求用户信息(scope为snsapi_base时无此步骤)
10服务器将用户信息回送给微信公众账号(scope为snsapi_base时无此步骤)
(需要配置配置授权回调页面域名)
用户授权并获取code ,使用code换取access_token 并使用access_token获取用户信息
授权访问的URL:
第一个参数为appId
第二个参数为授权后回调的地址http://域名/oauth
第三个参数为state 重定向后会带上state参数,开发者可以填写a-zA-Z0-9的参数值,最多128字节 第四个参数 应用授权作用域,简单讲是否弹出授权页面 。 true 为不弹出授权页面 (可以把用户信息储存到缓存里面state就是缓存key)
应用授权作用域,snsapi_base (不弹出授权页面,直接跳转,只能获取用户openid),snsapi_userinfo (弹出授权页面,可通过openid拿到昵称、性别、所在地。并且,即使在未关注的情况下,只要用户授权,也能获取其信息)
当用户同意授权,获取code以及state
如果code不为null,就可以通过code换取网页授权access_token
{
"access_token":"ACCESS_TOKEN",
"expires_in":7200,
"refresh_token":"REFRESH_TOKEN",
"openid":"OPENID",
"scope":"SCOPE"
}
拉取用户信息(需scope为 snsapi_userinfo)
{
"openid":" OPENID",
" nickname": NICKNAME,
"sex":"1",
"province":"PROVINCE"
"city":"CITY",
"country":"COUNTRY",
"headimgurl": "http://wx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ
4eMsv84eavHiaiceqxibJxCfHe/46",
"privilege":[ "PRIVILEGE1" "PRIVILEGE2" ],
"unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL"
}
获取用户信息之后可以根据自己的需求跳转到不同的页面
网友评论