前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >微信小程序-用户授权获取信息

微信小程序-用户授权获取信息

作者头像
别盯着我的名字看
发布2022-06-09 11:16:44
1.4K0
发布2022-06-09 11:16:44
举报
文章被收录于专栏:前端专栏前端专栏

从2018年4月30日开始,小程序与小游戏的体验版、开发版调用 wx.getUserInfo 接口,将无法弹出授权询问框,默认调用失败(但不意味着 wx.getUserInfo 不能用了)。小程序官网上提供两种方式来获取用户信息。

1、使用 open-data 展示用户基本信息

open-data是小程序提供的不需要用户授权获取用户信息的组件,但是不能通过js来拿值,所以只能作为开发人员快速开发显示用的。

代码语言:javascript
复制
<open-data type="userAvatarUrl"></open-data> 获取用户头像
<open-data type="userNickName"></open-data> 获取用户昵称
...

官网文档:open-data开放展示用户信息组件

2、使用 button 组件,并将 open-type 指定为 getUserInfo 类型,获取用户基本信息(重要)

在之前使用wx.getUserInfo不受限制,在js任何地方都可以使用,可能是为了防止滥用它,微信就改成必须通过button组件来获取

用户点击按钮授权

wxml:

代码语言:javascript
复制
<button open-type="getUserInfo" bindgetuserinfo="getUserInfo">登陆</button>

js:

代码语言:javascript
复制
getUserInfo: function (e) {
    const userInfo = e.detail.userInfo;
    console.log(userInfo);
},

通过上面的代码就能获取授权弹窗

定义一个方法判断用户是否授权

在上面的代码基础上增加一个判断是否授权的方法wx.getSetting 这是微信提供的API,获取用户的当前设置。返回值中只会出现小程序已经向用户请求过的权限。

代码语言:javascript
复制
Page({
  data: {
    
  },
  onLoad: function (options) {
    const that = this;
    that.userAuthorized();
  },
  //判断用户是否授权
  userAuthorized: function (e) {
    var that = this;
    wx.getSetting({
      success: function (data) {
        if (data.authSetting["scope.userInfo"]) {
          wx.getUserInfo({
            success: function (data) {
              console.log("用户已经授权")
            }
          })
        }
      }
    })
  },
  //点击登陆 授权
  getUserInfo: function (e) {
    const userInfo = e.detail.userInfo;
    console.log(userInfo);
  },
})
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-5-7,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、使用 open-data 展示用户基本信息
  • 2、使用 button 组件,并将 open-type 指定为 getUserInfo 类型,获取用户基本信息(重要)
    • 用户点击按钮授权
      • 定义一个方法判断用户是否授权
      相关产品与服务
      云开发 CloudBase
      云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档