Thinkphp5微信小程序獲取用戶信息接口的實(shí)例詳解
Thinkphp5微信小程序獲取用戶信息接口的實(shí)例詳解
首先在官網(wǎng)下載示例代碼, 選php的,
這里有個(gè)坑
官方的php文件,編碼是UTF-8+的, 所以要把文件改為UTF-8
然后在Thinkphp5 extend文件夾下建立Wxxcx命名空間,把官方的幾個(gè)類文件放進(jìn)去(這里要注意文件夾名, 命名空間名, 類名的, 大小寫,一定要一樣,官方的文件名和類名大小寫不一樣)
然后是自己的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ù)為封裝的請(qǐng)求函數(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請(qǐng)求方法
* @param string $url 請(qǐng)求URL
* @param array $params 請(qǐng)求參數(shù)
* @param string $method 請(qǐng)求方法GET/POST
* @return array $data 響應(yīng)數(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ù)請(qǐng)求類型設(shè)置特定參數(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('不支持的請(qǐng)求方式!');
}
/* 初始化并執(zhí)行curl請(qǐng)求 */
$ch = curl_init();
curl_setopt_array($ch, $opts);
$data = curl_exec($ch);
$error = curl_error($ch);
curl_close($ch);
if($error) throw new Exception('請(qǐng)求發(fā)生錯(cuò)誤:' . $error);
return $data;
}
然后是小程序的代碼:
// 獲取用戶信息
wx.getSetting({
success: res => {
if (res.authSetting['scope.userInfo']) {
// 已經(jīng)授權(quán),可以直接調(diào)用 getUserInfo 獲取頭像昵稱,不會(huì)彈框
wx.getUserInfo({
success: res => {
console.log(res);
var encryptedData = res.encryptedData
var iv = res.iv
wx.request({
url: "https://你的服務(wù)器地址/dologin",//dologin是訪問(wèn)后端的方法
method: "post",
data: {
code: code,
encryptedData: encryptedData,
iv: iv
},
success: function (ret) {
console.log(ret);
}
})
// 可以將 res 發(fā)送給后臺(tái)解碼出 unionId
this.globalData.userInfo = res.userInfo
// 由于 getUserInfo 是網(wǎng)絡(luò)請(qǐng)求,可能會(huì)在 Page.onLoad 之后才返回
// 所以此處加入 callback 以防止這種情況
if (this.userInfoReadyCallback) {
this.userInfoReadyCallback(res)
}
}
})
}
}
})
},
如果有報(bào)錯(cuò), 自己調(diào)試一下, 看看哪里的變量有問(wèn)題 查找原因.
如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
JavaScript專題之underscore防抖實(shí)例學(xué)習(xí)
這篇文章主要為大家介紹了JavaScript專題之underscore防抖實(shí)例學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
PerformanceObserver自動(dòng)獲取首屏?xí)r間實(shí)現(xiàn)示例
今天給大家介紹一個(gè)非常好用的瀏覽器api:?PerformanceObserver?,?我們可以用它來(lái)獲取首屏、白屏的時(shí)間,就不用再麻煩地手動(dòng)去計(jì)算了2022-07-07
使用?JS?復(fù)制頁(yè)面內(nèi)容的三種方案
這篇文章主要為大家介紹了使用?JS?復(fù)制頁(yè)面內(nèi)容的三種方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
關(guān)于JavaScript防抖與節(jié)流的區(qū)別與實(shí)現(xiàn)
這篇文章主要介紹關(guān)于JavaScript防抖與節(jié)流的區(qū)別與實(shí)現(xiàn),防抖就是用戶多次觸發(fā)事件,在用戶一直觸發(fā)事件中,事件不會(huì)執(zhí)行,只有在用戶停止觸發(fā)事件一段時(shí)間之后再執(zhí)行這個(gè)事件一次,二節(jié)流是用戶多次觸發(fā)事件,具體詳情一i起來(lái)學(xué)習(xí)下面文章內(nèi)容吧2021-10-10
微信小程序之選項(xiàng)卡的實(shí)現(xiàn)方法
這篇文章主要介紹了 微信小程序之選項(xiàng)卡的實(shí)現(xiàn)方法的相關(guān)資料,希望大家通過(guò)本文能實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-09-09
5種方法告訴你如何使JavaScript 代碼庫(kù)更干凈
J avaScript無(wú)處不在,從PC端到移動(dòng)設(shè)備端,甚至是后端,都在使用JavaSc ript。在本文中,將嘗試一些可用來(lái)使代碼看起來(lái)更簡(jiǎn)潔的實(shí)踐方案,希望能幫助到大家2021-09-09
JS前端宏任務(wù)微任務(wù)及Event Loop使用詳解
這篇文章主要為大家介紹了JS前端宏任務(wù)微任務(wù)及Event Loop使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
微信小程序開(kāi)發(fā)之相冊(cè)選擇和拍照詳解及實(shí)例代碼
這篇文章主要介紹了微信小程序開(kāi)發(fā)之相冊(cè)選擇和拍照詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02
微信小程序 checkbox組件詳解及簡(jiǎn)單實(shí)例
這篇文章主要介紹了微信小程序 checkbox組件詳解及簡(jiǎn)單實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-01-01

