微信小程序获取unionid与openid

获取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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<?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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<?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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
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工程师,欢迎大家关注!

posted @   Japer_01  阅读(11738)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示