欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序用戶(hù)授權(quán)環(huán)節(jié)實(shí)現(xiàn)過(guò)程

 更新時(shí)間:2023年01月31日 09:09:23   作者:前端施工員  
這篇文章主要介紹了微信小程序用戶(hù)授權(quán)環(huán)節(jié)實(shí)現(xiàn)過(guò)程,在商城項(xiàng)目中,我們需要對(duì)部分的頁(yè)面,進(jìn)行一個(gè)授權(quán)的判別,例如購(gòu)物車(chē),及個(gè)人中心,需要完成用戶(hù)信息的授權(quán)后,獲取到相關(guān)信息

在商城項(xiàng)目中,我們需要對(duì)部分的頁(yè)面,進(jìn)行一個(gè)授權(quán)的判別,例如購(gòu)物車(chē),及個(gè)人中心,需要完成用戶(hù)信息的授權(quán)后,獲取到相關(guān)信息

因?yàn)椴恢挂粋€(gè)頁(yè)面的跳轉(zhuǎn)需要此授權(quán)校驗(yàn)的功能,所以我們選擇封裝一個(gè)授權(quán)校驗(yàn)的公共組件,跳轉(zhuǎn)到需要驗(yàn)證的頁(yè)面,需要進(jìn)行授權(quán)登錄

公共組件權(quán)限判斷

封裝公共組件,在需要使用校驗(yàn)的地方引入,進(jìn)行判斷

邏輯判斷:

存入了手機(jī)號(hào),則校驗(yàn)中的回調(diào)函數(shù)允許執(zhí)行

未存入手機(jī)號(hào),則先判斷有無(wú)存入微信授權(quán)信息,(有的話(huà),去存手機(jī)號(hào),沒(méi)有的話(huà),先去存授權(quán)信息)

function CheckAuth(callback){
  // wx.getStorageSync 獲取微信本地存儲(chǔ)
  // 判斷是否有存入手機(jī)號(hào)進(jìn)本地存儲(chǔ)
  if(wx.getStorageSync('tel')){
    //處理業(yè)務(wù)
    callback()
  }else{
    // 沒(méi)有存入手機(jī)號(hào),但是判斷是否有認(rèn)證信息的 token
    if(wx.getStorageSync('token')){
      wx.navigateTo({
        url: '/pages/telform/telform',
      })
      // 沒(méi)有存入手機(jī)號(hào),也沒(méi)有 token 認(rèn)證信息
    }else{
      wx.navigateTo({
        url: '/pages/auth/auth',
      })
    }
  }
}
export default CheckAuth

例如,shopcar 購(gòu)物車(chē)組件:

校驗(yàn)通過(guò)情況:(已登陸過(guò))

在進(jìn)行獲取購(gòu)物車(chē)數(shù)據(jù)前,觸發(fā) CheckAuth( ),且傳入其中的回調(diào)函數(shù)為獲取對(duì)應(yīng)列表數(shù)據(jù),若有手機(jī)號(hào),則運(yùn)行執(zhí)行該回調(diào)函數(shù),獲取數(shù)據(jù),渲染數(shù)據(jù)

  /*** 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面顯示*/
  onShow() {
    // 驗(yàn)證通過(guò)后可以觸發(fā)回調(diào)函數(shù)
    CheckAuth(()=>{
      let {nickName} = wx.getStorageSync('token')
      let tel = wx.getStorageSync('tel')
      request({
        url:`/carts?_expand=good&username=${nickName}&tel=${tel}`
      }).then(res=>{
       this.setData({
         cartList:res
       })
      })
     })
  },

校驗(yàn)未通過(guò)情況:(未存入任何信息,首次登陸)

未獲取到本地的存儲(chǔ)授權(quán)信息及賬號(hào)信息,則進(jìn)行頁(yè)面的跳轉(zhuǎn),跳轉(zhuǎn)至授權(quán)頁(yè)面

function CheckAuth(callback){
    // 已存入過(guò)手機(jī)號(hào),直接可獲取數(shù)據(jù)
  if(wx.getStorageSync('tel')){
    //處理業(yè)務(wù)
    callback()
  }
    // 沒(méi)有存入手機(jī)號(hào),但是判斷是否有認(rèn)證信息的 token
    else{
    if(wx.getStorageSync('token')){
      wx.navigateTo({
        url: '/pages/telform/telform',
      })   
    }
     // 沒(méi)有存入手機(jī)號(hào),也沒(méi)有 token 認(rèn)證信息
     else{
      wx.navigateTo({
        url: '/pages/auth/auth',
      })
    }
  }
}

微信授權(quán)驗(yàn)證wx.getUserProfile()

使用 wx.getUserProfile( ) 獲取當(dāng)前微信的信息

驗(yàn)證成功后,在成功回調(diào)函數(shù)里存儲(chǔ) token 信息,再次跳轉(zhuǎn)至手機(jī)號(hào)存儲(chǔ)頁(yè)面

  // 獲取 微信授權(quán) 驗(yàn)證
  handleAuth(){
    wx.getUserProfile({
      desc: '用于完善會(huì)員資料',
      success:(res)=>{
        wx.setStorageSync('token', res.userInfo)
        wx.navigateTo({
          url: '/pages/telform/telform',
        })
      }
    })
  },

手機(jī)號(hào)帳號(hào)信息驗(yàn)證

頁(yè)面結(jié)構(gòu):

<mp-form-page title="綁定手機(jī)號(hào)" subtitle="驗(yàn)證微信賬號(hào)后需要綁定手機(jī)號(hào)">
  <mp-cells title="信息">
    <mp-cell>
      <input class="weui-input" placeholder="請(qǐng)輸入手機(jī)號(hào)" bindinput="formInputChange" />
      <view slot="footer" class="weui-vcode-btn">獲取驗(yàn)證碼</view>
    </mp-cell>
  </mp-cells>
  <view slot="button">
    <button class="weui-btn" type="primary" bindtap="submitForm">確定</button>
  </view>
</mp-form-page>

引入 WeUI:

{
  "usingComponents": {
    "mp-form-page": "weui-miniprogram/form-page/form-page",
    "mp-form": "weui-miniprogram/form/form",
    "mp-cells": "weui-miniprogram/cells/cells",
    "mp-cell": "weui-miniprogram/cell/cell"
  },
  "navigationBarTitleText": "手機(jī)號(hào)綁定"
}

提交手機(jī)號(hào):

未存入過(guò)信息,使用 post 請(qǐng)求存入新數(shù)據(jù),跳轉(zhuǎn)回正常使用頁(yè)面

存入過(guò)了信息,不再重復(fù)存,跳轉(zhuǎn)回正常使用頁(yè)面

跳轉(zhuǎn)返回頁(yè)面:wx.navigateBack()

  // 點(diǎn)擊確定 提交手機(jī)號(hào)
  submitForm(){
    // 手機(jī)號(hào)存入本地
    wx.setStorageSync('tel', this.data.tel)
    // 試著去數(shù)據(jù)庫(kù)找一下,相同 手機(jī)號(hào) 和 微信驗(yàn)證 的數(shù)據(jù)是否有
    request({
      url:`/users?tel=${this.data.tel}&nickName=${wx.getStorageSync('token').nickName}`
    }).then(res=>{
      // 數(shù)據(jù)庫(kù)未存過(guò)信息,post請(qǐng)求,去數(shù)據(jù)庫(kù)中新建一個(gè)數(shù)據(jù),帶上token和手機(jī)號(hào)
      if(res.length===0) {
        request({
          url:`/users`,
          method:'post',
          data:{
            ...wx.getStorageSync('token'),
            tel:this.data.tel
          }
        }).then(res=>{
         // 回退兩級(jí),返回到 購(gòu)物車(chē) 或 個(gè)人中心
          wx.navigateBack({
            delta:2
          })
        })
      } 
      // 數(shù)據(jù)庫(kù)存過(guò)信息,就不再重復(fù)存入,跳轉(zhuǎn)回正常頁(yè)面使用即可
      else {
        wx.navigateBack({
          delta:2
        })
      }     
    })
  },

到此這篇關(guān)于微信小程序用戶(hù)授權(quán)環(huán)節(jié)實(shí)現(xiàn)過(guò)程的文章就介紹到這了,更多相關(guān)小程序用戶(hù)授權(quán)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js獲取對(duì)象的屬性值兩種方式

    js獲取對(duì)象的屬性值兩種方式

    這篇文章主要介紹了js獲取對(duì)象的屬性值兩種方式,在JavaScript中訪(fǎng)問(wèn)對(duì)象的屬性值可以通過(guò)點(diǎn)運(yùn)算符(.)或括號(hào)運(yùn)算符([])兩種方式,文中將兩種方式的代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-10-10
  • JS點(diǎn)擊鏈接后慢慢展開(kāi)隱藏著圖片的方法

    JS點(diǎn)擊鏈接后慢慢展開(kāi)隱藏著圖片的方法

    這篇文章主要介紹了JS點(diǎn)擊鏈接后慢慢展開(kāi)隱藏著圖片的方法,實(shí)例分析了javascript操作圖片的隱藏與現(xiàn)實(shí)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-02-02
  • js實(shí)現(xiàn)當(dāng)鼠標(biāo)移到表格上時(shí)顯示這一格全部?jī)?nèi)容的代碼

    js實(shí)現(xiàn)當(dāng)鼠標(biāo)移到表格上時(shí)顯示這一格全部?jī)?nèi)容的代碼

    下面小編就為大家?guī)?lái)一篇js實(shí)現(xiàn)當(dāng)鼠標(biāo)移到表格上時(shí)顯示這一格全部?jī)?nèi)容的代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-06-06
  • form表單轉(zhuǎn)Json提交的方法(推薦)

    form表單轉(zhuǎn)Json提交的方法(推薦)

    下面小編就為大家?guī)?lái)一篇form表單轉(zhuǎn)Json提交的方法(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-09-09
  • GoJs連線(xiàn)上的信息展示使用詳解

    GoJs連線(xiàn)上的信息展示使用詳解

    這篇文章主要為大家介紹了GoJs連線(xiàn)上的信息展示使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • vscode?對(duì)?typescript代碼調(diào)試的步驟

    vscode?對(duì)?typescript代碼調(diào)試的步驟

    在VS?Code中,要對(duì)?TypeScript代碼進(jìn)行調(diào)試,需要先編譯?TypeScript?代碼為JavaScript代碼,這篇文章主要介紹了vscode對(duì)typescript代碼調(diào)試的方法,需要的朋友可以參考下
    2023-03-03
  • 總結(jié)javascript中的六種迭代器

    總結(jié)javascript中的六種迭代器

    本文總結(jié)了javascript中的六種迭代器的使用實(shí)例,分別是forEach迭代器、every迭代器、some迭代器、reduce迭代器、map迭代器和fiter迭代器,有需要的小伙伴們可以參考借鑒。
    2016-08-08
  • 簡(jiǎn)單實(shí)例處理url特殊符號(hào)&處理(2種方法)

    簡(jiǎn)單實(shí)例處理url特殊符號(hào)&處理(2種方法)

    url里的參數(shù)內(nèi)容包含&符合,我有兩種方法解決一是:在頁(yè)面用JS轉(zhuǎn)碼;二是:在后端處理,另外還有網(wǎng)絡(luò)分享的一些方法,感興趣的朋友可以參考下哈
    2013-04-04
  • JavaScript使用performance實(shí)現(xiàn)查看內(nèi)存

    JavaScript使用performance實(shí)現(xiàn)查看內(nèi)存

    這篇文章主要為大家詳細(xì)介紹了JavaScript如何使用performance實(shí)現(xiàn)查看內(nèi)存,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-03-03
  • BootstrapValidator不觸發(fā)校驗(yàn)的實(shí)現(xiàn)代碼

    BootstrapValidator不觸發(fā)校驗(yàn)的實(shí)現(xiàn)代碼

    BootstrapValidator是基于bootstrap3的jquery表單驗(yàn)證插件,是最適合bootstrap框架的表單驗(yàn)證插件,本文給大家介紹BootstrapValidator不觸發(fā)校驗(yàn)的實(shí)現(xiàn)代碼,感興趣的朋友一起看看吧
    2016-09-09

最新評(píng)論