小兔网

实现微信小程序之授权登录

前言:由于微信官方修改了 getUserInfo 接口,所以现在无法实现一进入微信小程序就弹出授权窗口,只能通过 button 去触

发。

1.实现思路

自己写一个微信授权登录页面让用户实现点击的功能,也就是实现了通过 button 组件去触发 getUserInof 接口。在用户进入微

信小程序的时候,判断用户是否授权了,如果没有授权的话就显示下面“界面简介”的第一个图,让用户去执行授权的操作。如

果已经授权了,则直接跳过这个页面,进入首页。

相关免费学习推荐:微信小程序开发

2.界面简介

20210620145000189017312021062014500118704052

3.源码

login.wxml

<view wx:if="{{canIUse}}">    <view class='header'>        <image src='/images/wx_login.png'></image>    </view>     <view class='content'>        <view>申请获取以下权限</view>        <text>获得你的公开信息(昵称,头像等)</text>    </view>     <button class='bottom' type='primary' open-type="getUserInfo" lang="zh_CN" bindgetuserinfo="bindGetUserInfo">        授权登录    </button></view> <view wx:else>请升级微信版本</view>

login.wcss

.header {    margin: 90rpx 0 90rpx 50rpx;    border-bottom: 1px solid #ccc;    text-align: center;    width: 650rpx;    height: 300rpx;    line-height: 450rpx;} .header image {    width: 200rpx;    height: 200rpx;} .content {    margin-left: 50rpx;    margin-bottom: 90rpx;} .content text {    display: block;    color: #9d9d9d;    margin-top: 40rpx;} .bottom {    border-radius: 80rpx;    margin: 70rpx 50rpx;    font-size: 35rpx;}

login.json

{"navigationBarTitleText": "授权登录"}

login.js

代码的 wx.request 是我项目与后台的一些交互,可直接删除掉。

需要修改的地方:

记得自己补上 wx.switchTab 接口中的 url 属性,这是授权成功后跳转的页面路径,由于我的首页是 tarBar 页面,所以这里用

wx.switchTab ,如果不是 tarBar 页面的话,可以用 wx.navigateTo 和 wx.redirecTo 去跳转

Page({    data: {        //判断小程序的API,回调,参数,组件等是否在当前版本可用。        canIUse: wx.canIUse('button.open-type.getUserInfo')    },    onLoad: function () {        var that = this;        // 查看是否授权        wx.getSetting({            success: function (res) {                if (res.authSetting['scope.userInfo']) {                    wx.getUserInfo({                        success: function (res) {                            //从数据库获取用户信息                            that.queryUsreInfo();                            //用户已经授权过                            wx.switchTab({                                url: ''                            })                        }                    });                }            }        })    },    bindGetUserInfo: function (e) {        if (e.detail.userInfo) {            //用户按了允许授权按钮            var that = this;            //插入登录的用户的相关信息到数据库            wx.request({                url: getApp().globalData.urlPath + 'hstc_interface/insert_user',                data: {                    openid: getApp().globalData.openid,                    nickName: e.detail.userInfo.nickName,                    avatarUrl: e.detail.userInfo.avatarUrl,                    province:e.detail.userInfo.province,                    city: e.detail.userInfo.city                },                header: {                    'content-type': 'application/json'                },                success: function (res) {                    //从数据库获取用户信息                    that.queryUsreInfo();                    console.log("插入小程序登录用户信息成功!");                }            });            //授权成功后,跳转进入小程序首页            wx.switchTab({                url: ''              })        } else {            //用户按了拒绝按钮            wx.showModal({                title:'警告',                content:'您点击了拒绝授权,将无法进入小程序,请授权之后再进入!!!',                showCancel:false,                confirmText:'返回授权',                success:function(res){                    if (res.confirm) {                        console.log('用户点击了“返回授权”')                    }                 }            })        }    },    //获取用户信息接口    queryUsreInfo: function () {        wx.request({            url: getApp().globalData.urlPath + 'hstc_interface/queryByOpenid',            data: {                openid: getApp().globalData.openid            },            header: {                'content-type': 'application/json'            },            success: function (res) {                console.log(res.data);                getApp().globalData.userInfo = res.data;            }        });    },    })

相关免费学习推荐:微信小程序开发教程

以上就是实现微信小程序之授权登录的知识。速戳>>知识兔学习精品课!