mirror of
https://gitee.com/fudiwei/DotNetCore.SKIT.FlurlHttpClient.Wechat.git
synced 2025-04-05 17:37:54 +08:00
1.7 KiB
1.7 KiB
如何解密回调通知事件中的敏感数据?
请先自行阅读:
密钥文件格式说明:
需要注意的是,平台为商户提供的是 PEM 格式的密钥文件,需区分文件格式之间的不同。
有关密钥文件格式的更多介绍,请参阅本文档《基础用法 - 如何加密请求中的敏感数据?》的有关章节。
解密流程
对于回调通知事件的敏感信息,微信商户平台使用了商户 API v3 密钥基于 AES-GCM 算法加密。
开发者可利用本库提供的 AESUtility
工具类自行解密相关字段。
此外,本库还封装了直接解密事件的扩展方法,下面给出一个示例代码:
/* 微信商户平台发来的通知内容 */
string webhookJson = "{ ... }";
/* 将 JSON 反序列化得到通知对象 */
/* 你也可以将 WechatTenpayEvent 类型直接绑定到 MVC 模型上,这样就不再需要手动反序列化 */
var webhookModel = client.DeserializeEvent(webhookJson);
if ("TRANSACTION.SUCCESS".Equals(webhookModel.EventType))
{
/* 根据事件类型,解密得到支付通知敏感数据 */
var webhookResource = client.DecryptEventResource<Events.TransactionResource>(webhookModel);
string outTradeNumber = webhookResource.OutTradeNumber;
string transactionId = webhookResource.TransactionId;
}
完整的回调通知模型定义可以参考项目目录下的 src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Events 目录。