亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Thinkphp5微信小程序獲取用戶信息接口的實例詳解

 更新時間:2017年09月26日 15:16:31   作者:encircles  
這篇文章主要介紹了Thinkphp5微信小程序獲取用戶信息接口的實例詳解的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下

Thinkphp5微信小程序獲取用戶信息接口的實例詳解

首先在官網(wǎng)下載示例代碼, 選php的,

這里有個坑

官方的php文件,編碼是UTF-8+的, 所以要把文件改為UTF-8

然后在Thinkphp5 extend文件夾下建立Wxxcx命名空間,把官方的幾個類文件放進去(這里要注意文件夾名, 命名空間名, 類名的, 大小寫,一定要一樣,官方的文件名和類名大小寫不一樣)

然后是自己的thinkphp接口代碼:

<?php 
/** 
 * Created by PhpStorm. 
 * User: leeoo 
 * Date: 2017/9/14 0014 
 * Time: 10:43 
 */ 
 
namespace app\api\controller\v1; 
 
 
use think\Loader; 
use think\Request; 
use Workerman\Protocols\Http; 
use Wxxcx\WXBizDataCrypt; 
use first\second\Foo; 
 
class Index 
{ 
  public function index($id) 
  { 
 
    return json(['msg' => $id]); 
  } 
 
  public function dologin() 
  { 
    $code = Request::instance()->param('code'); 
    $encryptedData = Request::instance()->param('encryptedData'); 
    $iv = Request::instance()->param('iv'); 
 
    $appid = "你的小程序appid"; 
    $secret = "你的小程序secret"; 
    //appid={$appid}&secret={$secret}&js_code={$code}&grant_type=authorization_code 
    $param = array( 
      'appid' => $appid, 
      'secret' => $secret, 
      'js_code' => $code, 
      'grant_type' => 'authorization_code' 
    ); 
  //http函數(shù)為封裝的請求函數(shù) 
    $res = http("https://api.weixin.qq.com/sns/jscode2session", $param, 'post'); 
 
    $arr = json_decode($res, true); 
 
    $result = $this->wxdecode($encryptedData, $iv, $arr['session_key'], $appid); 
 
    //return json($result); 
    if ($result) { 
      return json(['code' => 1]); 
    } else { 
      return json(['code' => -1]); 
    } 
 
  } 
 
  public function wxdecode($encryptedData, $iv, $sessionKey, $appid) 
  { 
    //Loader::import('Wxxcx\WXBizDataCrypt', EXTEND_PATH); 
    $pc = new WXBizDataCrypt($appid, $sessionKey); 
    $data = null; 
    $errCode = $pc->decryptData($encryptedData, $iv, $data); 
    //echo $data; 
    //return json(['data'=>$data]); 
    $data = json_decode($data); 
 
    if ($errCode == 0) { 
      //print($data . "\n"); 
      //dump($data); 
      return $data; 
    } else { 
      //print($errCode . "\n"); 
      //dump($errCode); 
      return $errCode; 
    } 
 
  } 
} 

http封裝函數(shù):

/** 
 * 發(fā)送HTTP請求方法 
 * @param string $url  請求URL 
 * @param array $params 請求參數(shù) 
 * @param string $method 請求方法GET/POST 
 * @return array $data  響應數(shù)據(jù) 
 */ 
function http($url, $params, $method = 'GET', $header = array(), $multi = false){ 
  $opts = array( 
    CURLOPT_TIMEOUT    => 30, 
    CURLOPT_RETURNTRANSFER => 1, 
    CURLOPT_SSL_VERIFYPEER => false, 
    CURLOPT_SSL_VERIFYHOST => false, 
    CURLOPT_HTTPHEADER   => $header 
  ); 
  /* 根據(jù)請求類型設置特定參數(shù) */ 
  switch(strtoupper($method)){ 
    case 'GET': 
      $opts[CURLOPT_URL] = $url . '?' . http_build_query($params); 
      break; 
    case 'POST': 
      //判斷是否傳輸文件 
      $params = $multi ? $params : http_build_query($params); 
      $opts[CURLOPT_URL] = $url; 
      $opts[CURLOPT_POST] = 1; 
      $opts[CURLOPT_POSTFIELDS] = $params; 
      break; 
    default: 
      throw new Exception('不支持的請求方式!'); 
  } 
  /* 初始化并執(zhí)行curl請求 */ 
  $ch = curl_init(); 
  curl_setopt_array($ch, $opts); 
  $data = curl_exec($ch); 
  $error = curl_error($ch); 
  curl_close($ch); 
  if($error) throw new Exception('請求發(fā)生錯誤:' . $error); 
  return $data; 
} 

然后是小程序的代碼:

// 獲取用戶信息 
  wx.getSetting({ 
   success: res => { 
    if (res.authSetting['scope.userInfo']) { 
     // 已經(jīng)授權(quán),可以直接調(diào)用 getUserInfo 獲取頭像昵稱,不會彈框 
     wx.getUserInfo({ 
      success: res => { 
       console.log(res); 
       var encryptedData = res.encryptedData 
       var iv = res.iv 
       wx.request({ 
        url: "https://你的服務器地址/dologin",//dologin是訪問后端的方法 
        method: "post", 
        data: { 
         code: code, 
         encryptedData: encryptedData, 
         iv: iv 
        }, 
        success: function (ret) { 
         console.log(ret); 
        } 
       }) 
        
        
       // 可以將 res 發(fā)送給后臺解碼出 unionId 
       this.globalData.userInfo = res.userInfo 
 
       // 由于 getUserInfo 是網(wǎng)絡請求,可能會在 Page.onLoad 之后才返回 
       // 所以此處加入 callback 以防止這種情況 
       if (this.userInfoReadyCallback) { 
        this.userInfoReadyCallback(res) 
       } 
      } 
     }) 
    } 
   } 
  }) 
 }, 

如果有報錯, 自己調(diào)試一下, 看看哪里的變量有問題  查找原因.

如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • JavaScript專題之underscore防抖實例學習

    JavaScript專題之underscore防抖實例學習

    這篇文章主要為大家介紹了JavaScript專題之underscore防抖實例學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • PerformanceObserver自動獲取首屏時間實現(xiàn)示例

    PerformanceObserver自動獲取首屏時間實現(xiàn)示例

    今天給大家介紹一個非常好用的瀏覽器api:?PerformanceObserver?,?我們可以用它來獲取首屏、白屏的時間,就不用再麻煩地手動去計算了
    2022-07-07
  • 使用?JS?復制頁面內(nèi)容的三種方案

    使用?JS?復制頁面內(nèi)容的三種方案

    這篇文章主要為大家介紹了使用?JS?復制頁面內(nèi)容的三種方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 關(guān)于JavaScript防抖與節(jié)流的區(qū)別與實現(xiàn)

    關(guān)于JavaScript防抖與節(jié)流的區(qū)別與實現(xiàn)

    這篇文章主要介紹關(guān)于JavaScript防抖與節(jié)流的區(qū)別與實現(xiàn),防抖就是用戶多次觸發(fā)事件,在用戶一直觸發(fā)事件中,事件不會執(zhí)行,只有在用戶停止觸發(fā)事件一段時間之后再執(zhí)行這個事件一次,二節(jié)流是用戶多次觸發(fā)事件,具體詳情一i起來學習下面文章內(nèi)容吧
    2021-10-10
  • 微信小程序之選項卡的實現(xiàn)方法

    微信小程序之選項卡的實現(xiàn)方法

    這篇文章主要介紹了 微信小程序之選項卡的實現(xiàn)方法的相關(guān)資料,希望大家通過本文能實現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-09-09
  • 5種方法告訴你如何使JavaScript 代碼庫更干凈

    5種方法告訴你如何使JavaScript 代碼庫更干凈

    J avaScript無處不在,從PC端到移動設備端,甚至是后端,都在使用JavaSc ript。在本文中,將嘗試一些可用來使代碼看起來更簡潔的實踐方案,希望能幫助到大家
    2021-09-09
  • JS前端宏任務微任務及Event Loop使用詳解

    JS前端宏任務微任務及Event Loop使用詳解

    這篇文章主要為大家介紹了JS前端宏任務微任務及Event Loop使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • Iframe跨窗口通信原理詳解

    Iframe跨窗口通信原理詳解

    這篇文章主要為大家介紹了Iframe跨窗口通信原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 微信小程序開發(fā)之相冊選擇和拍照詳解及實例代碼

    微信小程序開發(fā)之相冊選擇和拍照詳解及實例代碼

    這篇文章主要介紹了微信小程序開發(fā)之相冊選擇和拍照詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • 微信小程序  checkbox組件詳解及簡單實例

    微信小程序 checkbox組件詳解及簡單實例

    這篇文章主要介紹了微信小程序 checkbox組件詳解及簡單實例的相關(guān)資料,需要的朋友可以參考下
    2017-01-01

最新評論