獲取unionid須要先在微信開放平臺綁定小程序,不然沒法獲取php
UnionID機制說明
unionid來區分用戶的惟一性,在相同微信開放平臺賬號下的移動應用、網站應用、小程序、公衆號,用戶的unionid是惟一的。也就是說,同一用戶,對同一個微信開放平臺下的不一樣應用,unionid是相同的。html
OpenID機制說明算法
OpenId是用來區分應用的惟一性,在相同微信開放平臺帳號下不用的應用,其unionid相同,OpenId而不一樣,好比說同一個微信開放平臺綁定了多個小程序應用,每一個應用的OpenId是不相同。json
UnionID獲取途徑
綁定了開發者賬號的小程序,能夠經過下面 3 種途徑獲取 UnionID。小程序
調用接口 wx.getUserInfo,從解密數據中獲取 UnionID。注意本接口須要用戶受權,請開發者妥善處理用戶拒絕受權後的狀況。後端
若是開發者賬號下存在同主體的公衆號,而且該用戶已經關注了該公衆號。開發者能夠直接經過 wx.login + code2Session 獲取到該用戶 UnionID,無須用戶再次受權。微信小程序
若是開發者賬號下存在同主體的公衆號或移動應用,而且該用戶已經受權登陸過該公衆號或移動應用。開發者也能夠直接經過 wx.login + code2Session 獲取到該用戶 UnionID ,無須用戶再次受權。api
UnionID獲取兩種實現方式:數組
① 經過小程序接口wx.getUserInfo,從解密數據中獲取 UnionID。微信
以上是微信參考文檔:https://developers.weixin.qq.com/miniprogram/dev/api/open-api/login/code2Session.html
經過解密wx.getUserInfo返回的 encryptedData來獲取
encryptedData爲加密後的字符串,經過微信官方的加密數據解密算法獲取,直接下載官方的demo,以PHP爲列
demo.php
<?php // 目錄入口 define('AESAPI_ROOT_PATH', dirname(__FILE__)."/AES"); //define('YUNAPI_URL', 'http://cmq-queue-gz.api.qcloud.com'); require_once AESAPI_ROOT_PATH . '/wxBizDataCrypt.php'; class AES { public function __construct() { // $this->appid = ''; // $this->sessionKey = ''; } /* * 解析$encryptedData參數 * @param $appid 小程序id * @param $encryptedData 加密串 * @param $iv 用戶iv * @param $sessionKey 用戶sessionKey * */ public function decryption($appid,$encryptedData,$iv,$sessionKey){ $pc = new WXBizDataCrypt($appid, $sessionKey); $errCode = $pc->decryptData($encryptedData, $iv, $data ); if ($errCode == 0) { return $data; } else { return $errCode; } } }
wxBizDataCrypt.php
<?php /** * 對微信小程序用戶加密數據的解密示例代碼. * * @copyright Copyright (c) 1998-2014 Tencent Inc. */ include_once "errorCode.php"; class WXBizDataCrypt { private $appid; private $sessionKey; /** * 構造函數 * @param $sessionKey string 用戶在小程序登陸後獲取的會話密鑰 * @param $appid string 小程序的appid */ public function __construct( $appid, $sessionKey) { $this->sessionKey = $sessionKey; $this->appid = $appid; } /** * 檢驗數據的真實性,而且獲取解密後的明文. * @param $encryptedData string 加密的用戶數據 * @param $iv string 與用戶數據一同返回的初始向量 * @param $data string 解密後的原文 * * @return int 成功0,失敗返回對應的錯誤碼 */ public function decryptData( $encryptedData, $iv, &$data ) { if (strlen($this->sessionKey) != 24) { return ErrorCode::$IllegalAesKey; } $aesKey=base64_decode($this->sessionKey); if (strlen($iv) != 24) { return ErrorCode::$IllegalIv; } $aesIV=base64_decode($iv); $aesCipher=base64_decode($encryptedData); $result=openssl_decrypt( $aesCipher, "AES-128-CBC", $aesKey, 1, $aesIV); $dataObj=json_decode( $result ); if( $dataObj == NULL ) { return ErrorCode::$IllegalBuffer; } if( $dataObj->watermark->appid != $this->appid ) { return ErrorCode::$IllegalBuffer; } $data = $result; return ErrorCode::$OK; } }
注意事項:會話密鑰 session_key 有效性,wx.login 調用時,用戶的 session_key 可能會被更新而導致舊 session_key 失效,每一個session_key只能使用一次。
解析參數以下:
②經過小程序wx.login獲取code,請求微信code2Session接口,獲取UnionID
public function getXcxUserInfo($code) { if (!$code) return array(); // 小程序專用信息 $appid = ''; // 南泥灣商戶版 $appsecret = ''; $url = "https://api.weixin.qq.com/sns/jscode2session?appid={$appid}&secret={$appsecret}&js_code={$code}&grant_type=authorization_code"; $res = $this->http_request($url); return $res; } /** * curl模擬http請求GET/POST * @param $url * @param null $data * @return array */ public function http_request($url, $data = null) { $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); // 以文件流形式返回 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); if (!empty($data)) { // POST請求 curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $data); } $output = curl_exec($ch); curl_close($ch); // 返回數組 return json_decode($output, true); }
至此,微信小程序unionid與openid都已成功獲取,你們在開發中特別注意要綁定微信開放平臺。
---------------------
做者:No.1117
來源:CSDN
原文:https://blog.csdn.net/qq_29920751/article/details/83109800
【PHPer技術棧】專一後端開發,倡導開源文化,作一個好玩、有趣、有靈魂的PHPer工程師,歡迎你們關注!