之前介绍过了如何在微信小程序中获取群openGId相关的流程,在这篇文章中我会使用php
实现之前提到过的相关接口。解析encryptedData
和iv
的代码官方已经给出了php
、nodejs
等版本的实现,这篇主要是贴一些相关代码。

准备
下载官方实例:https://mp.weixin.qq.com/debug/wxadoc/dev/demo/aes-sample.zip
在自己的代码中引入并设置相关常数:
1 2 3 4
| require_once('wxBizDataCrypt.php');
$appid= '...'; $appsecret= '...';
|
获取登录信息
根据微信小程序中通过wx.login
得到的code
获取用户对小程序的唯一标识openid
和session_key
,session_key
时会过期的。
当然,满足一定条件还会的到unionid
,具体可以查看官方文档。UnionID机制说明
1 2 3 4 5 6 7 8
| 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; }
|
解析加密信息
下面函数是根据官方示例改成的:
1 2 3 4 5 6 7 8 9 10
| 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
传过来的参数,进行调用获取openGId
:
1 2 3 4 5 6 7
| $code = ... $encryptedData = ... $iv = ...
$loginInfo = getInfoWithCode($appid, $appsecret, $code); $sessionKey = $loginInfo->session_key; echo getDecodeEncryptedData($sessionKey, $encryptedData, $iv);
|
前端拿到openGId
后就可以进行绑定相关操作了。
http_post
函数,是官方某个demo里的,具体是哪里的忘了:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| function http_post( $url, $data=null ) { $curl = curl_init(); curl_setopt($curl, CURLOPT_URL, $url); curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($curl, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); if($data != null){ curl_setopt($curl, CURLOPT_POST, 1); curl_setopt($curl, CURLOPT_POSTFIELDS, $data); } curl_setopt($curl, CURLOPT_TIMEOUT, 300); curl_setopt($curl, CURLOPT_HEADER, 0); curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); $info = curl_exec($curl); curl_close( $curl ); return $info; }
|
其实这些都可以从官方文档里找到,这里只是做一个总结。
因为我用过框架,上面代码是改变过的,没有进行实际测试,但思路就大概是这样的。
如果代码有什么问题可以告知我。
参考