微信 公众号用户授权流程

微信官方文档-公众号
关于网页授权回调域名的说明
1、在微信公众号请求用户网页授权之前,开发者需要先到公众平台官网中的“开发 - 接口权限 - 网页服务 - 网页帐号 - 网页授权获取用户基本信息”的配置选项中,修改授权回调域名。请注意,这里填写的是域名(是一个字符串),而不是URL,因此请勿加 http:// 等协议头;
2、授权回调域名配置规范为全域名,比如需要网页授权的域名为:***www.qq.com,***配置以后此域名下面的页面http://www.qq.com/music.html 、 http://www.qq.com/login.html 都可以进行OAuth2.0鉴权。但http://pay.qq.com 、 http://music.qq.com 、 http://qq.com 无法进行OAuth2.0鉴权
重点

1.以snsapi_userinfo为scope发起的网页授权,是用来获取用户的基本信息的。但这种授权需要用户手动同意,并且由于用户同意过,所以无须关注***,就可在授权后获取该用户的基本信息*。
2.对于已关注公众号的用户,如果用户从公众号的会话或者自定义菜单进入本公众号的网页授权页,即使是scope为snsapi_userinfo,也是静默授权,用户无感知。
步骤:
具体而言,网页授权流程分为四步:

  • 引导用户进入授权页面同意授权,获取code
  • 通过code换取网页授权access_token(与基础支持中的access_token不同)
  • 如果需要,开发者可以刷新网页授权access_token,避免过期
  • 通过网页授权access_token和openid获取用户基本信息(支持UnionID机制)
  1. 用户同意授权,获取code;scope为snsapi_userinfo
public static final String H5_AUTHORIZE_URL = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=%s&redirect_uri=%s&response_type=%s&scope=%s&state=%s#wechat_redirect";


用户授权参数说明

2.通过code换取网页授权access_token
首先请注意,这里通过code换取的是一个特殊的网页授权access_token,与基础支持中的access_token(该access_token用于调用其他接口)不同。公众号可通过下述接口来获取网页授权access_token。如果网页授权的作用域为snsapi_base,则本步骤中获取到网页授权access_token的同时,也获取到了openid,snsapi_base式的网页授权流程即到此为止。

public static final String  OAUTH_GET_TOKEN = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=AppId&secret=AppSecret&code=CODE&grant_type=authorization_code";

参数说明
返回参数说明
获取用户信息
拉取用户信息(需scope为 snsapi_userinfo)

public final static String SNS_USER_INFO = "https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN";

参数说明
正确json如下

{   
  "openid": "OPENID",
  "nickname": NICKNAME,
  "sex": 1,
  "province":"PROVINCE",
  "city":"CITY",
  "country":"COUNTRY",
  "headimgurl":"https://thirdwx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/46",
  "privilege":[ "PRIVILEGE1" "PRIVILEGE2"     ],
  "unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL"
}

返回参数说明

获取微信公众号的openid并实现用户授权流程,是开发者在构建基于微信平台的应用时经常会遇到的需求。为了深入了解这一过程,建议参阅《Html5页面获取微信公众号的openid的方法》,其中详细阐述了如何在HTML5页面中与微信公众号进行交互,以及如何处理用户授权获取openid。 参考资源链接:[Html5页面获取微信公众号的openid的方法](https://wenku.csdn.net/doc/6401abf9cce7214c316ea2ce?spm=1055.2569.3001.10343) 首先,需要确认你的HTML5页面是运行在微信浏览器中,并且已经与微信公众号进行了关联。通过检查sessionStorage或localStorage中是否已经存储了openid,可以判断是否需要进行授权操作。如果未存储openid,则需要引导用户进行授权。 接下来,判断URL的查询字符串参数中是否已经包含了'code'。如果存在'code',则可以直接将此'code'发送到后端服务器,以便进一步换取openid。如果不存在'code',则需要通过页面上的JavaScript代码跳转到微信提供的获取'code'的链接,并引导用户完成授权用户授权成功后,微信会回调指定的URL,并携带'code'参数。此时,后端服务器可以使用此'code'参数以及你的微信公众号的AppID和AppSecret向微信的服务器请求openid。成功获取到openid后,后端应将此openid存储在用户对应的记录中,并通过接口返回给前端进行本地存储,通常存储在sessionStorage或localStorage中,以便后续使用。 如果需要强制关注公众号获取openid,可以使用jsapi接口生成关注二维码,并弹窗展示。用户扫描二维码关注后,系统将引导用户回到页面,完成授权流程。 在整个过程中,需要特别注意安全性问题,如防止'code'被重复使用,以及保证openid的安全存储和传输。《Html5页面获取微信公众号的openid的方法》不仅提供了一个完整的实现流程,还涉及了这些重要的安全考虑,值得每一位开发者深入学习和实践。 参考资源链接:[Html5页面获取微信公众号的openid的方法](https://wenku.csdn.net/doc/6401abf9cce7214c316ea2ce?spm=1055.2569.3001.10343)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值