2021-07-27 18:37:38 +08:00
|
|
|
## 如何解密回调通知事件中的敏感数据?
|
2021-05-10 15:30:00 +08:00
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
> 请先自行阅读:
|
|
|
|
>
|
|
|
|
> [《微信支付开发者文档 - 开发指南:证书和回调报文解密》](https://pay.weixin.qq.com/wiki/doc/apiv3_partner/wechatpay/wechatpay4_2.shtml)
|
|
|
|
|
2021-11-25 21:15:54 +08:00
|
|
|
---
|
|
|
|
|
|
|
|
### 密钥文件格式说明:
|
|
|
|
|
|
|
|
需要注意的是,平台为商户提供的是 PEM 格式的密钥文件,需区分文件格式之间的不同。
|
|
|
|
|
2021-11-26 02:59:02 +08:00
|
|
|
有关密钥文件格式的更多介绍,请参阅本文档[《高级技巧 - 如何加密请求中的敏感数据?》](./Advanced_RequestSensitiveDataEncryption.md)的有关章节。
|
2021-11-25 21:15:54 +08:00
|
|
|
|
|
|
|
---
|
|
|
|
|
2021-12-28 14:05:39 +08:00
|
|
|
### 解密流程
|
2021-11-25 21:15:54 +08:00
|
|
|
|
2021-07-20 15:35:04 +08:00
|
|
|
对于回调通知事件的敏感信息,微信商户平台使用了商户公钥基于 RSA 算法加密。
|
2021-05-10 15:30:00 +08:00
|
|
|
|
2021-07-20 15:35:04 +08:00
|
|
|
开发者可利用本库提供的 `RSAUtility` 工具类自行解密相关字段。
|
2021-05-10 15:30:00 +08:00
|
|
|
|
2021-11-25 21:15:54 +08:00
|
|
|
此外,本库还封装了直接解密事件的扩展方法,下面给出一个示例代码:
|
2021-05-10 15:30:00 +08:00
|
|
|
|
|
|
|
```csharp
|
2021-07-20 15:35:04 +08:00
|
|
|
/* 微信商户平台发来的通知内容 */
|
|
|
|
string callbackJson = "{ ... }";
|
|
|
|
/* 将 JSON 反序列化得到通知对象 */
|
|
|
|
/* 你也可以将 WechatTenpayEvent 类型直接绑定到 MVC 模型上,这样就不再需要手动反序列化 */
|
|
|
|
var callbackModel = client.DeserializeEvent(callbackJson);
|
2021-05-10 15:30:00 +08:00
|
|
|
if ("TRANSACTION.SUCCESS".Equals(callbackModel.EventType))
|
|
|
|
{
|
2021-07-20 15:35:04 +08:00
|
|
|
/* 根据事件类型,解密得到支付通知敏感数据 */
|
|
|
|
var callbackResource = client.DecryptEventResource<Events.TransactionResource>(callbackModel);
|
2021-05-10 15:30:00 +08:00
|
|
|
string outTradeNumber = callbackResource.OutTradeNumber;
|
|
|
|
string transactionId = callbackResource.TransactionId;
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2021-05-28 19:27:50 +08:00
|
|
|
完整的回调通知模型定义可以参考项目目录下的 _src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Events_ 目录。
|