php获取微信uninoid_微信小程序获取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

// 目录入口

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

/**

* 对微信小程序用户加密数据的解密示例代码.

*

* @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工程师,欢迎大家关注!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值