獲取unionid需要先在微信開放平台綁定小程序,否則無法獲取
UnionID機制說明
unionid來區分用戶的唯一性,在相同微信開放平台帳號下的移動應用、網站應用、小程序、公眾號,用戶的unionid是唯一的。也就是說,同一用戶,對同一個微信開放平台下的不同應用,unionid是相同的。
OpenID機制說明
OpenId是用來區分應用的唯一性,在相同微信開放平台賬號下不用的應用,其unionid相同,OpenId而不同,比如說同一個微信開放平台綁定了多個小程序應用,每個應用的OpenId是不相同。
UnionID獲取途徑
綁定了開發者帳號的小程序,可以通過下面 3 種途徑獲取 UnionID。
調用接口 wx.getUserInfo,從解密數據中獲取 UnionID。注意本接口需要用戶授權,請開發者妥善處理用戶拒絕授權后的情況。
如果開發者帳號下存在同主體的公眾號,並且該用戶已經關注了該公眾號。開發者可以直接通過 wx.login + code2Session 獲取到該用戶 UnionID,無須用戶再次授權。
如果開發者帳號下存在同主體的公眾號或移動應用,並且該用戶已經授權登錄過該公眾號或移動應用。開發者也可以直接通過 wx.login + code2Session 獲取到該用戶 UnionID ,無須用戶再次授權。
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工程師,歡迎大家關注!

