网站建设
建站服务第一步:用户同意授权,获取code
获取code链接地址:
https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
APPID:公众号的唯一标识(开发者模式中查找)
REDIRECT_URI:授权后重定向的回调链接地址,请使用urlencode对链接进行处理(即获取code后跳转到的地址)
SCOPE:应用授权作用域,snsapi_base (不弹出授权页面,直接跳转,只能获取用户openid),snsapi_userinfo (弹出授权页面,可通过openid拿到昵称、性别、所在地。并且,即使在未关注的情况下,只要用户授权,也能获取其信息)
注:只需修改以上三处即可。
下图为scope等于snsapi_userinfo时的授权页面:
用户同意授权后
如果用户同意授权,页面将跳转至 redirect_uri/?code=CODE&state=STATE。若用户禁止授权,则重定向后不会带上code参数,仅会带上state参数redirect_uri?state=STATE
第二步:通过code换取网页授权access_token
首先请注意,这里通过code换取的是一个特殊的网页授权access_token,与基础支持中的access_token(该access_token用于调用其他接口)不同。公众号可通过下述接口来获取网页授权access_token。如果网页授权的作用域为snsapi_base,则本步骤中获取到网页授权access_token的同时,也获取到了openid,snsapi_base式的网页授权流程即到此为止。
请求链接:https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code
APPID:公众号的唯一标识(开发者模式中查找)
SECRET:公众号的appsecret(开发者模式中查找)
CODE:填写第一步获取的code参数
注:只需修改以上三处即可。
正确返回结果如下:
{ "access_token":"ACCESS_TOKEN", "expires_in":7200, "refresh_token":"REFRESH_TOKEN", "openid":"OPENID", "scope":"SCOPE", "unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL" }
第三步:拉取用户信息(需scope为 snsapi_userinfo)
请求方法如下:
http:GET(请使用https协议)https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN
ACCESS_TOKEN:网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同(第二步获得ACCESS_TOKEN)
OPENID:用户的唯一标识
注:只需修改以上二处即可。
正确返回结果如下:
{ "openid":" OPENID", " nickname": NICKNAME, "sex":"1", "province":"PROVINCE" "city":"CITY", "country":"COUNTRY", "headimgurl": "http://wx.qlogo.cn/mmopen/3AHtjI9wkCrUQyJYA9ibTa4XE4R7sxA20xPxg29Jk99SFklIHKaYsLqTdibyjRiauUcFmMmP4Z02JesKT1asStCicuovjHIXoe9H/0", "privilege":[ "PRIVILEGE1" "PRIVILEGE2" ], "unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL" }
正确返回结果如下:
openid:用户的唯一标识
nickname:用户昵称
sex:用户的性别,值为1时是男性,值为2时是女性,值为0时是未知
province:用户个人资料填写的省份
city:普通用户个人资料填写的城市
country:国家,如中国为CN
headimgurl:用户头像,最后一个数值代表正方形头像大小(有0、46、64、96、132数值可选,0代表640*640正方形头像),用户没有头像时该项为空。若用户更换头像,原有头像URL将失效。
unionid:只有在用户将公众号绑定到微信开放平台帐号后,才会出现该字段。详见:获取用户个人信息(UnionID机制)