微信小程序生态6—微信公众号授权登录(适用于H5小程序)

一、实现步骤

1 第一步:用户同意授权,获取code

2 第二步:通过code换取网页授权access_token

3 第三步:刷新access_token(如果需要)

4 第四步:拉取用户信息(需scope为 snsapi_userinfo)

5 附:检验授权凭证(access_token)是否有效

二、准备材料

一个服务号(已认证),确保网页授权权限已开通

三、实现步骤

1. 点击修改,跳转到公众号设置页,此处需要添加一个域名文件校验

2. 通过authorize获取的code

调用open.weixin.qq.com/connect/oau... 我这里写了一个简单HTML,用来发起调用接口:

xml 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8"/>
    <meta http-equiv="X-UA-Compatible" content="IE=edge"/>
    <meta name="viewport" content="width=device-width, initial-scale=1.0"/>
    <title>Document</title>
</head>
<style>
</style>
<body>
<div id="container">
</div>
<script>
    window.appId = `${appId}`
   //注意:此处redirect_uri需要使用encodeURIComponent(该方法浏览器自带)转义
    let local = "http://xxx"
    // 跳转到授权页面
    window.location.href =
            "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" +
            window.appId +
            "&redirect_uri=" +
            encodeURIComponent(local) +
            "&response_type=code&scope=snsapi_userinfo&state=1#wechat_redirect";
</script>
</body>
</html>

3. 参数说明

snsapi_base与snsapi_userinfo属于微信网页授权获取用户信息的两种作用域

  • snsapi_base只能获取access_token和openId

  • snsapi_userinfo可以获取更详细的用户资料,比如头像、昵称、性别等,该种形式会唤醒授权页面

4. 调用接口获取access_token

api.weixin.qq.com/sns/oauth2/...

返回值如下

json 复制代码
{
    "access_token":"accesstoken",
    "refresh_token":"refreshtoken",
    "openid":"openId",
    "scope":"snsapi_userinfo",
    "expires_in":7200
 }

5. 根据accessToken和openId查询用户信息

调用api.weixin.qq.com/sns/userinf...

返回值如下

json 复制代码
{
    "country":"",
    "province":"",
    "city":"",
    "openid":"openid",
    "sex":0,
    "nickname":"sum墨",
    "headimgurl":"xxx",
    "language":"",
    "privilege":[]
  }

三、常见错误码发生情况

json 复制代码
{
    "errcode":40029,
    "errmsg":"invalid code, rid: 620e3db2-410d5515-117f31ac"
 }

这种问题一般都发生在code上,要检查code是不是有值并且是不是重复调用了

相关推荐
Mr-Wanter1 分钟前
vue 数据反显时数字/字母不换行导致的样式问题
前端·javascript·vue.js
梁萌9 分钟前
vue项目从npm升级为pnpm
前端·npm·node.js
修己xj10 分钟前
CSS魔法:对话生成器与奔驰骏马的创意实现
前端·css
拽着尾巴的鱼儿11 分钟前
Spring定时任务 Scheduled使用
java·后端·spring
贾修行24 分钟前
IIS 作为反向代理:为 ASP.NET Core Kestrel 应用保驾护航
后端·iis·asp.net·反向代理·arr·url 重写规则
琹箐29 分钟前
Cursor 无法使用prettier格式化
前端
觉醒大王32 分钟前
如何整理文献阅读笔记? (精读与泛读)
前端·css·笔记·深度学习·自然语言处理·html·学习方法
广州华水科技1 小时前
单北斗GNSS变形监测系统在水库安全监测中的应用与发展
前端
We་ct1 小时前
LeetCode 58. 最后一个单词的长度:两种解法深度剖析
前端·算法·leetcode·typescript
夏河始溢1 小时前
一八零、AG-UI:构建AI前端交互的统一协议
前端·人工智能·ui