微信小程序获取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工程师,欢迎大家关注!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· 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