mirror of
https://gitee.com/fudiwei/DotNetCore.SKIT.FlurlHttpClient.Wechat.git
synced 2025-07-15 23:13:32 +08:00
80 lines
3.4 KiB
C#
80 lines
3.4 KiB
C#
using System.IO;
|
||
using System.Text;
|
||
using System.Threading.Tasks;
|
||
using Microsoft.AspNetCore.Mvc;
|
||
using Microsoft.Extensions.Logging;
|
||
|
||
namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Sample.Controllers
|
||
{
|
||
[ApiController]
|
||
[Route("api/notify")]
|
||
public class TenpayNotifyController : ControllerBase
|
||
{
|
||
private readonly ILogger _logger;
|
||
private readonly Services.HttpClients.IWechatTenpayClientFactory _wechatTenpayClientFactory;
|
||
|
||
public TenpayNotifyController(
|
||
ILoggerFactory loggerFactory,
|
||
Services.HttpClients.IWechatTenpayClientFactory wechatTenpayClientFactory)
|
||
{
|
||
_logger = loggerFactory.CreateLogger(GetType());
|
||
_wechatTenpayClientFactory = wechatTenpayClientFactory;
|
||
}
|
||
|
||
|
||
[HttpPost]
|
||
[Route("m-{merchant_id}/message-push")]
|
||
public async Task<IActionResult> ReceiveMessage(
|
||
[FromRoute(Name = "merchant_id")] string merchantId,
|
||
[FromHeader(Name = "Wechatpay-Timestamp")] string timestamp,
|
||
[FromHeader(Name = "Wechatpay-Nonce")] string nonce,
|
||
[FromHeader(Name = "Wechatpay-Signature")] string signature,
|
||
[FromHeader(Name = "Wechatpay-Serial")] string serialNumber)
|
||
{
|
||
using var reader = new StreamReader(Request.Body, Encoding.UTF8);
|
||
string content = await reader.ReadToEndAsync();
|
||
_logger.LogInformation("接收到微信支付推送的数据:{0}", content);
|
||
|
||
var client = _wechatTenpayClientFactory.Create(merchantId);
|
||
bool valid = client.VerifyEventSignature(
|
||
webhookTimestamp: timestamp,
|
||
webhookNonce: nonce,
|
||
webhookBody: content,
|
||
webhookSignature: signature,
|
||
webhookSerialNumber: serialNumber
|
||
);
|
||
if (!valid)
|
||
{
|
||
// NOTICE:
|
||
// 需提前注入 CertificateManager、并下载平台证书,才可以使用扩展方法执行验签操作。
|
||
// 请参考本示例项目 TenpayCertificateRefreshingBackgroundService 后台任务中的相关实现。
|
||
// 有关 CertificateManager 的完整介绍请参阅《开发文档 / 基础用法 / 如何验证回调通知事件签名?》。
|
||
// 后续如何解密并反序列化,请参阅《开发文档 / 基础用法 / 如何解密回调通知事件中的敏感数据?》。
|
||
|
||
return new JsonResult(new { code = "FAIL", message = "验签失败" });
|
||
}
|
||
|
||
var callbackModel = client.DeserializeEvent(content);
|
||
var eventType = callbackModel.EventType?.ToUpper();
|
||
switch (eventType)
|
||
{
|
||
case "TRANSACTION.SUCCESS":
|
||
{
|
||
var callbackResource = client.DecryptEventResource<Events.TransactionResource>(callbackModel);
|
||
_logger.LogInformation("接收到微信支付推送的订单支付成功通知,商户订单号:{0}", callbackResource.OutTradeNumber);
|
||
// 后续处理略
|
||
}
|
||
break;
|
||
|
||
default:
|
||
{
|
||
// 其他情况略
|
||
}
|
||
break;
|
||
}
|
||
|
||
return new JsonResult(new { code = "SUCCESS", message = "成功" });
|
||
}
|
||
}
|
||
}
|