摘要

因为获取用户信息的接口 wx.getUserInfo 存在滥用,使用不规范等原因,微信官方已经将这个接口权限回收,改为用户信息填写,即引导用户主动填写微信昵称和上传头像。这种做法确实是麻烦了点。

但是微信小程序插件,还是可以使用 wx.getUserInfo 接口的,我们可以开发一个插件,通过插件调用这个接口,获得用户昵称和头像,然后将用户昵称和头像保存下来即可。

接口文档:https://developers.weixin.qq.com/miniprogram/dev/framework/pl...

文档说明

用户信息功能页

用户信息功能页用于帮助插件获取用户信息,包括 openid 和昵称等,相当于 wx.loginwx.getUserInfo 的功能。

在基础库版本 2.3.1 前,用户信息功能页是插件中唯一的获取 code 和用户信息的方式;

自基础库版本 2.3.1 起,用户在该功能页中进行过授权后,插件可以直接调用 wx.loginwx.getUserInfo

授权是以【用户 + 小程序 + 插件】为维度进行授权的,即同一个用户在不同小程序中使用同一个插件,或同一个小程序中使用不同插件,都需要单独进行授权自基础库版本 2.6.3 起,可以使用 wx.getSetting 来查询用户是否授权过,另外,在满足以下任一条件时,插件可以直接 wx.login

  1. 使用插件的小程序与插件拥有相同的 AppId
  2. 使用插件的小程序与插件绑定了同一个 微信开放平台 账号,且使用插件的小程序与插件均与开放平台账号为同主体或关联主体
  3. 不满足以上条件时,wx.loginwx.getUserInfo 将返回失败。

开发

在开发之前,你需要申请一个小程序插件。

image.png

然后使用官方示例代码,就可以简单使用这个插件。

image.png

代码也是非常简单的,一个是小程序页面,另一个是插件页面。

image.png

示例代码

<!--plugin/components/hello-component.wxml-->
  <functional-page-navigator
    name="loginAndGetUserInfo"
    args="{{ args }}"
    version="develop"
    bind:success="loginSuccess"
    bind:fail="loginFail"
  >
    <button class="login">登录到插件</button>
  </functional-page-navigator>
// plugin/components/hello-component.js
Component({
  properties: {},
  data: {
    args: {
      withCredentials: true,
      lang: 'zh_CN'
    }
  },
  methods: {
    loginSuccess: function (res) {
      console.log(res.detail);
    },
    loginFail: function (res) {
      console.log(res);
    }
  }
});

然后在小程序的页面json文件配置这个插件。

image.png

app.json还需要加入:

image.png

"functionalPages": {
    "independent": true
},

在WXML文件引入这个组件。

image.png

预览

因为index.wxml是引入插件的组件,直接就显示 plugin/components/login/login.wxml 的内容了。

image.png

image.png

点击授权登录,就会跳转到官方的【用户信息功能页】插件,这个插件页面是无法修改样式的。

image.png

点击【允许使用】就会获取到用户的昵称和头像。

image.png

其中 res.detail.userInfo.avatarUrl 就是头像地址,res.detail.userInfo.nickName 就是微信昵称,获取这两个之后,可以自己进一步处理。

image.png

作者

TANKING


TANKING
4.8k 声望493 粉丝

热爱分享,热爱创作,热爱研究。