濮阳杆衣贸易有限公司

主頁 > 知識庫 > php實現(xiàn)微信小程序授權(quán)登錄功能(實現(xiàn)流程)

php實現(xiàn)微信小程序授權(quán)登錄功能(實現(xiàn)流程)

熱門標(biāo)簽:江門回?fù)芡夂粝到y(tǒng) 杭州語音電銷機(jī)器人 電銷機(jī)器人沒有效果怎么樣 天潤融通外呼系統(tǒng)好嗎 高德地圖標(biāo)注店鋪收費嗎 高德地圖標(biāo)注位置怎么標(biāo)注 江西電銷機(jī)器人收費 泊頭在哪里辦理400電話 欣思維地圖標(biāo)注

先上圖

實現(xiàn)流程:

1、授權(quán)登陸按鈕和正文信息放到了同一個頁面,未授權(quán)的時候顯示登陸按鈕,已授權(quán)的時候隱藏登陸按鈕,顯示正文信息,當(dāng)然也可以授權(quán)和正文分開成兩個頁面,在授權(quán)頁面的onload里判斷是否已授權(quán),若已授權(quán)就直接跳轉(zhuǎn)正文的頁面。這里只說授權(quán)按鈕和正文在同一頁面的情況。

2、在onload里先判斷是否已授權(quán),如果已授權(quán),就隱藏授權(quán)登陸按鈕,顯示正文信息,如果沒有授權(quán),顯示授權(quán)登陸按鈕。

3、前端使用button的open-type="getUserInfo"來操作,點擊授權(quán)按鈕之后,“e”中會攜帶userInfo,用戶的基本信息(和使用wx.getUserInfo接口獲取的數(shù)據(jù)一樣,所以我是在"e"里面直接取的,沒有調(diào)用wx.getUserInfo接口)

4、使用wx.login接口獲取登陸憑證code,使用code去后解密換取openid,傳輸code的時候帶上第3步獲取的用戶信息一塊發(fā)送給后臺解密(也可以不攜帶,攜帶的目的是為了驗證簽名,這樣安全一些,不驗證也可以)

5、后臺解密使用的是“auth.code2Session”接口,解密用到的SDK下載地址

“https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/signature.html”。

5、后臺解密之后(后臺語言用的是php),會返回openid等敏感信息,就還可以把這些信息存起來了。

6、獲取授權(quán)成功之后,再隱藏授權(quán)登陸按鈕,顯示正文信息。

7、如果用戶點擊拒絕授權(quán),提示引導(dǎo)用戶再次授權(quán)。

注意,要考慮到授權(quán)失敗的情況

以下是詳細(xì)代碼

wxml

view wx:if="{{isHide}}">
  view wx:if="{{canIUse}}" >
    view class='header'>
      image src='/images/icon/wx_login.png'>/image>
    /view>
 
    view class='content'>
      view>申請獲取以下權(quán)限/view>
      text>獲得你的公開信息(昵稱,頭像等)/text>
    /view>
 
    button class='bottom' type='primary' open-type="getUserInfo" lang="zh_CN" bindgetuserinfo="bindGetUserInfo">
      授權(quán)登錄
    /button>
  /view>
  view wx:else>請升級微信版本/view>
/view>
 
view wx:else>
  view>我的首頁內(nèi)容/view>
/view>

wxss

.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;
}

js

// pages/test1/test1.js
var app = getApp();
Page({
 /**
  * 頁面的初始數(shù)據(jù)
  */
 data: {
  //判斷小程序的API,回調(diào),參數(shù),組件等是否在當(dāng)前版本可用。
  canIUse: wx.canIUse('button.open-type.getUserInfo'),
  isHide: false
 },
 /**
  * 生命周期函數(shù)--監(jiān)聽頁面加載
  */
 onLoad: function (options) {
  var that = this;
  // 查看是否授權(quán)
  wx.getSetting({
   success: function (res) {
    if (!res.authSetting['scope.userInfo']) {
     // 還未授權(quán),顯示授權(quán)按鈕
     that.setData({
      isHide: true
     });
    } else {
     // 已授權(quán),隱藏授權(quán)按鈕,顯示正文
     that.setData({
      isHide: false
     });
    }
   }
  })
 },
 //授權(quán)登陸按鈕
 bindGetUserInfo: function (e) {
  var that = this;
  console.log(e)
  if (e.detail.userInfo) {
   //用戶授權(quán)登陸,并跳轉(zhuǎn)首頁
   // that.getOpenid()
   wx.login({
    success: function (res) {
     // 請求自己后臺獲取用戶openid
     wx.request({
      url: app.domain + 'teacherapi/Wx_Decode/WxDecode',
      method: 'POST',
      header: { 'content-type': 'application/x-www-form-urlencoded' },
      data: {
       encryptedData: e.detail.encryptedData,
       signature: e.detail.signature,
       rawData: e.detail.rawData,
       iv: e.detail.iv,
       code: res.code
      },
      success: function (res_user) {
       if (res_user.data.status == 0) {
        var data = JSON.parse(res_user.data.msg)    //json轉(zhuǎn)對象
        //授權(quán)成功返回的數(shù)據(jù),根據(jù)自己需求操作
        console.log(data)
        //授權(quán)成功后,隱藏授權(quán)按鈕,顯示正文
        that.setData({
         isHide: false
        });
       }
      }, fail: function () {
       that.showModal('獲取授權(quán)信息失敗')
      }
     })
    }
   })
  } else {
   //用戶按了拒絕授權(quán)按鈕,提示引導(dǎo)授權(quán)
   that.showModal('請授權(quán)后使用小程序')
  }
 },
 //未授權(quán)彈窗
 showModal: function (e) {
  wx.showModal({
   title: '提示',
   content: e,
   showCancel: false,
   confirmText: '返回授權(quán)',
   success: function (res) {
    if (res.confirm) {
     console.log('用戶點擊了“返回授權(quán)”')
    }
   }
  })
 },
})

php

?php
namespace app\teacherapi\controller;
use think\Controller;
/**
* @date: 2018-12
* 微信操作類
*/
class WxDecode extends Controller
{
  public function httpGet($url) {
    $curl = curl_init();
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($curl, CURLOPT_TIMEOUT, 500);
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
    curl_setopt($curl, CURLOPT_URL, $url);
    $res = curl_exec($curl);
    curl_close($curl);
    return $res;
  }
  /**
   * @author: zxf
   * @date: 2018-12-08
   * @description: 解密微信用戶敏感數(shù)據(jù)
   * @return array
   */
  public function WxDecode()
  {
    // 接收參數(shù)
    $data = request() -> param();
    // 引入解密文件 在微信小程序開發(fā)文檔下載
    vendor('wx.WXBizDataCrypt');
    vendor('wx.ErrorCode');
    $appid = config('TESTPPID');
    $appsecret = config('TESTSECREET');
    $grant_type = "authorization_code"; //授權(quán)(必填)
    $code = $data['code'];    //有效期5分鐘 登錄會話
    $encryptedData=$data['encryptedData'];
    $iv = $data['iv'];
    $signature = $data['signature'];
    $rawData = $data['rawData'];
    // 拼接url
    $url = "https://api.weixin.qq.com/sns/jscode2session?"."appid=".$appid."secret=".$appsecret."js_code=".$code."grant_type=".$grant_type;
    $res = json_decode($this->httpGet($url),true);
    $sessionKey = $res['session_key']; //取出json里對應(yīng)的值
    $signature2 = sha1(htmlspecialchars_decode($rawData).$sessionKey);
    // 驗證簽名
    if ($signature2 !== $signature){
      return json("驗簽失敗");
    } 
    // 獲取解密后的數(shù)據(jù)
    $pc = new \WXBizDataCrypt($appid, $sessionKey);
    $errCode = $pc->decryptData($encryptedData, $iv, $data );
    if ($errCode == 0) {
      return return_succ($data);
    } else {
      return return_error($errCode);
    }
  }
}

您可能感興趣的文章:
  • 微信小程序 消息推送php服務(wù)器驗證實例詳解
  • php基于Redis消息隊列實現(xiàn)的消息推送的方法
  • php實現(xiàn)微信模板消息推送
  • php實現(xiàn)websocket實時消息推送
  • 解析php做推送服務(wù)端實現(xiàn)ios消息推送
  • PHP實現(xiàn)微信小程序在線支付功能(代碼實例)
  • 微信小程序發(fā)送訂閱消息的方法(php 為例)
  • 基于PHP實現(xiàn)微信小程序客服消息功能
  • 微信小程序上傳圖片到php服務(wù)器的方法
  • 詳解php微信小程序消息推送配置

標(biāo)簽:江門 深圳 內(nèi)江 駐馬店 雙鴨山 大同 石嘴山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php實現(xiàn)微信小程序授權(quán)登錄功能(實現(xiàn)流程)》,本文關(guān)鍵詞  php,實現(xiàn),微信,小,程序,授權(quán),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php實現(xiàn)微信小程序授權(quán)登錄功能(實現(xiàn)流程)》相關(guān)的同類信息!
  • 本頁收集關(guān)于php實現(xiàn)微信小程序授權(quán)登錄功能(實現(xiàn)流程)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    杂多县| 封开县| 宁强县| 佛教| 沭阳县| 明水县| 伊金霍洛旗| 邯郸县| 无极县| 石楼县| 内江市| 新安县| 祁东县| 万源市| 安顺市| 澎湖县| 娱乐| 永吉县| 墨脱县| 高尔夫| 葵青区| 达日县| 广南县| 毕节市| 城口县| 临沂市| 龙井市| 阳高县| 万载县| 永清县| 海伦市| 松阳县| 达孜县| 乐都县| 保定市| 康平县| 旬邑县| 湖南省| 青浦区| 甘孜| 工布江达县|