微信小程序之授權登錄的實現(附完整源碼)

目錄

1.實現思路

2.界面簡介

3.源碼

同類文章推薦:


前言:由於微信官方修改了 getUserInfo 接口,所以現在無法實現一進入微信小程序就彈出授權窗口,只能通過 button 去觸

發。官方連接:點擊打開鏈接

1.實現思路

自己寫一個微信授權登錄頁面讓用戶實現點擊的功能,也就是實現了通過 button 組件去觸發 getUserInof 接口。在用戶進入微

信小程序的時候,判斷用戶是否授權了,如果沒有授權的話就顯示下面“界面簡介”的第一個圖,讓用戶去執行授權的操作。如

果已經授權了,則直接跳過這個頁面,進入首頁。

2.界面簡介

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;
            }
        });
    },
    
})

補充:

關於 getApp().globalData.openid 拿不到值的說明:是因爲我已經在全局 js 文件 app.js 那裏作了賦值。

就是當用戶進入小程序的時候,就獲取到用戶的 opneid 然後放到全局變量 openid 中。下面直接看下代碼就好。

app.js

App({
    /**
     * 當小程序初始化完成時,會觸發 onLaunch(全局只觸發一次)
     */
    onLaunch: function () {
        var that = this;
        wx.login({
            success:res=>{
                wx.request({
                    url: that.globalData.wx_url_1 + res.code + that.globalData.wx_url_2,
                    success:res=>{
                        that.globalData.openid = res.data.openid;
                    }
                })
            }
        });
    },

    /**
     * 設置全局變量
     */
    globalData: {
        openid:0,
        wx_url_1: 'https://api.weixin.qq.com/sns/jscode2session?appid=自己的APPID&secret=自己的SECRET&js_code=',
        wx_url_2: '&grant_type=authorization_code'
    }
})

 

代碼比較簡單,就不作太多的解釋,不懂可以提問。

 

 

有什麼問題的話,可以評論留言,大家交流一下!

 

同類文章推薦:

微信小程序之側邊欄滑動實現(附完整源碼)             

微信小程序之下拉列表實現(附完整源碼)           

 

更多小程序乾貨可關注博主新開的公衆號:

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章