.NET Core 微信公眾號小程序6種獲取UnionID方法,你知道哪幾種?
- 2019 年 10 月 18 日
- 筆記
前言
獲取UnionID是開發微信公眾號/小程序中很有必要的一個環節,特別是針對一個公司擁有多個公眾號小程序而推出的機制,實現打通賬戶一體化,用UnionID來區分多平台的唯一性。
官方的解釋:如果開發者擁有多個移動應用、網站應用、和公眾帳號(包括小程序),可通過 UnionID 來區分用戶的唯一性,因為只要是同一個微信開放平台帳號下的移動應用、網站應用和公眾帳號(包括小程序),用戶的 UnionID 是唯一的。換句話說,同一用戶,對同一個微信開放平台下的不同應用,unionid是相同的。
相關開發文章:
.NET Core 小程序開發零基礎系列(1)——開發者啟用並牽手成功
.NET Core 小程序開發零基礎系列(2)——小程序服務通知(模板消息)
目錄
1、UnionID機制說明
2、UnionID獲取的6種途徑(代碼實現)
3、總結
UnionID機制說明
如果開發者擁有多個移動應用、網站應用、和公眾帳號(包括小程序),可通過 UnionID 來區分用戶的唯一性,因為只要是同一個微信開放平台帳號下的移動應用、網站應用和公眾帳號(包括小程序),用戶的 UnionID 是唯一的。換句話說,同一用戶,對同一個微信開放平台下的不同應用,unionid是相同的。
UnionID獲取的6種途徑(代碼實現)
綁定了開發者帳號的小程序,可以通過以下途徑獲取 UnionID
UnionID獲取的6種途徑
-
調用接口 wx.getUserInfo,從解密數據中獲取 UnionID。注意本接口需要用戶授權,請開發者妥善處理用戶拒絕授權後的情況。
-
如果開發者帳號下存在同主體的公眾號,並且該用戶已經關注了該公眾號。開發者可以直接通過 wx.login +
code2Session
獲取到該用戶 UnionID,無須用戶再次授權。 -
如果開發者帳號下存在同主體的公眾號或移動應用,並且該用戶已經授權登錄過該公眾號或移動應用。開發者也可以直接通過 wx.login +
code2Session
獲取到該用戶 UnionID ,無須用戶再次授權。 -
用戶在小程序(暫不支持小遊戲)中支付完成後,開發者可以直接通過
getPaidUnionId
接口獲取該用戶的 UnionID,無需用戶授權。注意:本接口僅在用戶支付完成後的5分鐘內有效,請開發者妥善處理。 -
小程序端調用雲函數時,如果開發者帳號下存在同主體的公眾號,並且該用戶已經關注了該公眾號,可在雲函數中通過 cloud.getWXContext 獲取 UnionID。
-
小程序端調用雲函數時,如果開發者帳號下存在同主體的公眾號或移動應用,並且該用戶已經授權登錄過該公眾號或移動應用,也可在雲函數中通過 cloud.getWXContext 獲取 UnionID。
第一種UnionID獲取
調用接口 wx.getUserInfo,從解密數據中獲取 UnionID。注意本接口需要用戶授權,請開發者妥善處理用戶拒絕授權後的情況。
最常見的一種,很多同學應該用的這種。
流程:用戶授權——獲取密鑰——後端解密——獲取UnionID
開放平台綁定小程序如圖:
前端授權獲取密鑰:
後端解密獲取UnionID
varsettingItem = Senparc.Weixin.Config.SenparcWeixinSetting.Items[appID]; JsCode2JsonResult jsonResult = SnsApi.JsCode2Json(settingItem.WxOpenAppId, settingItem.WxOpenAppSecret, param.Code); if (jsonResult.errcode != ReturnCode.請求成功) { return (false, jsonResult.errmsg); } string unionID; var encryptedData = Senparc.Weixin.WxOpen.Helpers.EncryptHelper.DecodeEncryptedData(jsonResult.session_key, param.EncryptedData, param.IV); DecodedUserInfo decodedUserInfo = SerializerHelper.GetObject<DecodedUserInfo>(encryptedData); unionID = decodedUserInfo.unionId;
第二種UnionID獲取
如果開發者帳號下存在同主體的公眾號,並且該用戶已經關注了該公眾號。開發者可以直接通過 wx.login + code2Session 獲取到該用戶 UnionID,無須用戶再次授權。
流程:關注了公眾號——獲取UnionID
1、關注同一主體公眾號就好了
2、獲取UnionID,如下代碼
varsettingItem = Senparc.Weixin.Config.SenparcWeixinSetting.Items[appID]; JsCode2JsonResult jsonResult = SnsApi.JsCode2Json(settingItem.WxOpenAppId, settingItem.WxOpenAppSecret, param.Code); if (jsonResult.errcode != ReturnCode.請求成功) { return (false, jsonResult.errmsg); } string unionID; if (!jsonResult.unionid.IsNullOrEmpty()) { unionID = jsonResult.unionid; Console.WriteLine($"unionID獲取(無需解密):參數EncryptedData={param.EncryptedData},IV={param.IV},unionID={unionID}"); }
第三種UnionID獲取
如果開發者帳號下存在同主體的公眾號或移動應用,並且該用戶已經授權登錄過該公眾號或移動應用。開發者也可以直接通過 wx.login + code2Session 獲取到該用戶 UnionID ,無須用戶再次授權。
流程:與第二步流程類似,可以參數
第四種UnionID獲取
用戶在小程序(暫不支持小遊戲)中支付完成後,開發者可以直接通過getPaidUnionId接口獲取該用戶的 UnionID,無需用戶授權。注意:本接口僅在用戶支付完成後的5分鐘內有效,請開發者妥善處理。
流程:訂單支付成功得到相應信息——通過接口請求getPaidUnionId得到UnionID
1、支付流程請參考:.NET Core 微信小程序支付——(統一下單)
2、通過接口請求getPaidUnionId得到UnionID
以下兩種方式任選其一。
a、微信支付訂單號(transaction_id)
https://api.weixin.qq.com/wxa/getpaidunionid?access_token=ACCESS_TOKEN&openid=OPENID&transaction_id=TRANSACTION_ID
b、微信支付商戶訂單號和微信支付商戶號(out_trade_no 及 mch_id)
https://api.weixin.qq.com/wxa/getpaidunionid?access_token=ACCESS_TOKEN&openid=OPENID&mch_id=MCH_ID&out_trade_no=OUT_TRADE_NO
通過兩個接口請求方式就可以得到UnionID
第五種UnionID獲取
小程序端調用雲函數時,如果開發者帳號下存在同主體的公眾號,並且該用戶已經關注了該公眾號,可在雲函數中通過 cloud.getWXContext 獲取 UnionID。
流程:關注了公眾號——通過雲函數獲取UnionID
官方函數說明:
代碼示例:
const cloud = require('wx-server-sdk') exports.main = async (event, context) => { const { OPENID, APPID, UNIONID, ENV, } = cloud.getWXContext() return { OPENID, APPID, UNIONID, ENV, } }
第六種UnionID獲取
小程序端調用雲函數時,如果開發者帳號下存在同主體的公眾號或移動應用,並且該用戶已經授權登錄過該公眾號或移動應用,也可在雲函數中通過 cloud.getWXContext 獲取 UnionID。
流程:與第五種類似,可以參數。
總結
獲取UnionID是開發微信眾號/小程序很有必要的一個環節,主要為了打通微信多平台體系下的唯一性,6種方式中,其實最關鍵的一步是將當前開發的應用綁定在開放平台上,希望這篇文章讓你對UnionID有些新的認識,也希望這篇實戰文章能夠真正的幫助到你。