微信公众号开发相关

相关概念


appid:公众号的唯一标识


openId:加密后的微信号,每个用户对每个公众号的OpenID是唯一的。对于不同公众号,同一用户的openid不同


accessToken:是公众号的全局唯一接口调用凭据,公众号调用各接口时都需使用。开发者需要进行妥善保存。accessToken的存储至少要保留512个字符空间。accessTtoken的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的accessToken失效。


scope:
1.scope=snsapi_base:是用来获取进入页面的用户的openid的,并且是静默授权并自动跳转到回调页的。用户感知的就是直接进入了回调页(往往是业务页面)
2.scope=snsapi_userinfo:网页授权,是用来获取用户的基本信息的。但这种授权需要用户手动同意,并且由于用户同意过,所以无须关注,就可在授权后获取该用户的基本信息。
关于特殊场景下的静默授权:
1.上面已经提到,对于以snsapi_base为scope的网页授权,就静默授权的,用户无感知;
2.对于已关注公众号的用户,如果用户从公众号的会话或者自定义菜单进入本公众号的网页授权页,即使是scope为snsapi_userinfo,也是静默授权,用户无感知。


网页授权相关步骤

1、用户同意授权,获取code:在确保微信公众账号拥有授权作用域(scope参数)的权限的前提下(服务号获得高级接口后,默认拥有scope参数中的snsapi_basesnsapi_userinfo),引导关注者打开如下页面:

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}、{SCOPE}部分,如果不需要显示用户授权页面也就是使用静默的方式获取授权,就将{SCOPE}替换为snsapi_base
2、通过code换取网页授权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 

其中{CODE}就是第一步骤中获取的code值

{ 
    "access_token":"ACCESS_TOKEN",    
    "expires_in":7200,    
    "refresh_token":"REFRESH_TOKEN",    
    "openid":"OPENID",    
    "scope":"SCOPE"
 } 
参数 描述
access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
expires_in access_token接口调用凭证超时时间,单位(秒)
refresh_token 用户刷新access_token
openid 用户唯一标识,请注意,在未关注公众号时,用户访问公众号的网页,也会产生一个用户和公众号唯一的OpenID
scope 用户授权的作用域,使用逗号(,)分隔

3、刷新access_token(如果需要)

https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=APPID&grant_type=refresh_token&refresh_token=REFRESH_TOKEN 

|参数 |是否必须 |说明|
| ------------- |:-----------:|: ---------:|
|appid |是 |公众号的唯一标识|
|grant_type| 是| 填写为refresh_token|
|refresh_token| 是 |填写通过access_token获取到的refresh_token参数 |
4、拉取用户信息(需scope为 snsapi_userinfo)

 https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN 

参数说明

参数 描述
access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
openid 用户的唯一标识
lang 返回国家地区语言版本,zh_CN 简体,zh_TW 繁体,en 英语

返回说明

{   
   "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" 
} 
参数 描述
openid 用户的唯一标识
nickname 用户昵称
sex 用户的性别,值为1时是男性,值为2时是女性,值为0时是未知
province 用户个人资料填写的省份
city 普通用户个人资料填写的城市
country 国家,如中国为CN
headimgurl 用户头像,最后一个数值代表正方形头像大小(有0、46、64、96、132数值可选,0代表640*640正方形头像),用户没有头像时该项为空。若用户更换头像,原有头像URL将失效。
privilege 用户特权信息,json 数组,如微信沃卡用户为(chinaunicom)
unionid 只有在用户将公众号绑定到微信开放平台帐号后,才会出现该字段。

你可能感兴趣的:(微信公众号开发相关)