1. 程式人生 > >微信小程式獲取unionid與openid

微信小程式獲取unionid與openid

獲取unionid需要先在微信開放平臺繫結小程式,否則無法獲取

UnionID機制說明  unionid來區分使用者的唯一性,在相同微信開放平臺帳號下的移動應用、網站應用、小程式、公眾號,使用者的unionid是唯一的。也就是說,同一使用者,對同一個微信開放平臺下的不同應用,unionid是相同的。

OpenID機制說明

OpenId是用來區分應用的唯一性,在相同微信開放平臺賬號下不用的應用,其unionid相同,OpenId而不同,比如說同一個微信開放平臺綁定了多個小程式應用,每個應用的OpenId是不相同。

UnionID獲取途徑

綁定了開發者帳號的小程式,可以通過下面 3 種途徑獲取 UnionID。

  1. 呼叫介面 wx.getUserInfo,從解密資料中獲取 UnionID。注意本介面需要使用者授權,請開發者妥善處理使用者拒絕授權後的情況。

  2. 如果開發者帳號下存在同主體的公眾號,並且該使用者已經關注了該公眾號。開發者可以直接通過 wx.login + code2Session 獲取到該使用者 UnionID,無須使用者再次授權。

  3. 如果開發者帳號下存在同主體的公眾號或移動應用,並且該使用者已經授權登入過該公眾號或移動應用。開發者也可以直接通過 wx.login + code2Session 獲取到該使用者 UnionID ,無須使用者再次授權。

UnionID獲取兩種實現方式:

① 通過小程式介面wx.getUserInfo,從解密資料中獲取 UnionID。

通過解密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都已成功獲取,大家在開發中特別注意要繫結微信開放平臺