之前介紹過了如何在微信小程序中獲取群openGId相關(guān)的流程,在這篇文章中我會使用php實(shí)現(xiàn)之前提到過的相關(guān)接口。解析encryptedData和iv的代碼官方已經(jīng)給出了php、nodejs等版本的實(shí)現(xiàn),這篇主要是貼一些相關(guān)代碼。

基本思路
準(zhǔn)備
下載官方實(shí)例:https://mp.weixin.qq.com/debug/wxadoc/dev/demo/aes-sample.zip
在自己的代碼中引入并設(shè)置相關(guān)常數(shù):
-
require_once('wxBizDataCrypt.php');
-
-
$appid= '...'; //小程序 AppID
-
$appsecret= '...'; //小程序 AppSecret
獲取登錄信息
根據(jù)微信小程序中通過wx.login得到的code獲取用戶對小程序的唯一標(biāo)識openid和session_key,session_key時(shí)會過期的。
當(dāng)然,滿足一定條件還會的到unionid,具體可以查看官方文檔。UnionID機(jī)制說明
-
function getInfoWithCode($appid, $appsecret, $code) {
-
$url = "https://api.weixin.qq.com/sns/jscode2session?appid=".$appid."&secret=".$appsecret."&js_code=".$code."&grant_type=authorization_code";
-
$reData = http_post($url, array());
-
-
$obj = json_decode($reData);
-
-
return $obj;
-
}
解析加密信息
下面函數(shù)是根據(jù)官方示例改成的:
-
function getDecodeEncryptedData($sessionKey, $encryptedData, $iv) {
-
$pc = new WXBizDataCrypt($appid, $sessionKey);
-
$errCode = $pc->decryptData($encryptedData, $iv, $data );
-
-
if ($errCode == 0) {
-
return $data;
-
} else {
-
return $errCode;
-
}
-
}
最后獲取post傳過來的參數(shù),進(jìn)行調(diào)用獲取openGId:
-
$code = ... // post 參數(shù)
-
$encryptedData = ... // post 參數(shù)
-
$iv = ... // post 參數(shù)
-
-
$loginInfo = getInfoWithCode($appid, $appsecret, $code);
-
$sessionKey = $loginInfo->session_key;
-
echo getDecodeEncryptedData($sessionKey, $encryptedData, $iv);
前端拿到openGId后就可以進(jìn)行綁定相關(guān)操作了。
http_post函數(shù),是官方某個(gè)demo里的,具體是哪里的忘了:
-
function http_post( $url, $data=null ) {
-
$curl = curl_init(); // 啟動一個(gè)CURL會話
-
curl_setopt($curl, CURLOPT_URL, $url); // 要訪問的地址
-
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); // 對認(rèn)證證書來源的檢查
-
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); // 從證書中檢查SSL加密算法是否存在
-
curl_setopt($curl, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); // 模擬用戶使用的瀏覽器
-
if($data != null){
-
curl_setopt($curl, CURLOPT_POST, 1); // 發(fā)送一個(gè)常規(guī)的Post請求
-
curl_setopt($curl, CURLOPT_POSTFIELDS, $data); // Post提交的數(shù)據(jù)包
-
}
-
curl_setopt($curl, CURLOPT_TIMEOUT, 300); // 設(shè)置超時(shí)限制防止死循環(huán)
-
curl_setopt($curl, CURLOPT_HEADER, 0); // 顯示返回的Header區(qū)域內(nèi)容
-
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 獲取的信息以文件流的形式返回
-
$info = curl_exec($curl); // 執(zhí)行操作
-
curl_close( $curl );
-
// var_dump(json_decode($resp, true));
-
// echo " ";
-
return $info;
-
}
其實(shí)這些都可以從官方文檔里找到,這里只是做一個(gè)總結(jié)。
因?yàn)槲矣眠^框架,上面代碼是改變過的,沒有進(jìn)行實(shí)際測試,但思路就大概是這樣的。
如果代碼有什么問題可以告知我。
參考
|