using System.Threading.Tasks; using Essensoft.Paylink.Alipay; using Essensoft.Paylink.Alipay.Notify; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; namespace WebApplicationSample.Controllers { [Route("alipay/notify")] public class AlipayNotifyController : Controller { private readonly ILogger _logger; private readonly IAlipayNotifyClient _client; private readonly IOptions _optionsAccessor; public AlipayNotifyController(ILogger logger, IAlipayNotifyClient client, IOptions optionsAccessor) { _logger = logger; _client = client; _optionsAccessor = optionsAccessor; } /// /// 应用网关 /// /// [Route("gateway")] [HttpPost] public async Task Gateway() { try { var msg_method = Request.Form["msg_method"].ToString(); switch (msg_method) { // 资金单据状态变更通知 case "alipay.fund.trans.order.changed": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } // 第三方应用授权取消消息 case "alipay.open.auth.appauth.cancelled": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } // 用户授权取消消息 case "alipay.open.auth.userauth.cancelled": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } // 小程序审核通过通知 case "alipay.open.mini.version.audit.passed": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } // 小程序审核驳回通知 case "alipay.open.mini.version.audit.rejected": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } // 收单退款冲退完成通知 case "alipay.trade.refund.depositback.completed": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } // 收单资金结算到银行账户,结算退票的异步通知 case "alipay.trade.settle.dishonoured": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } // 收单资金结算到银行账户,结算失败的异步通知 case "alipay.trade.settle.fail": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } // 收单资金结算到银行账户,结算成功的异步通知 case "alipay.trade.settle.success": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } // 身份认证记录消息 case "alipay.user.certify.open.notify.completed": { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); return AlipayNotifyResult.Success; } default: return AlipayNotifyResult.Failure; } } catch (AlipayException ex) { _logger.LogWarning("出现异常: " + ex.Message); return AlipayNotifyResult.Failure; } } /// /// 扫码支付异步通知 /// [Route("precreate")] [HttpPost] public async Task Precreate() { try { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); switch (notify.TradeStatus) { case AlipayTradeStatus.Wait: // 等待付款 _logger.LogInformation("扫码支付异步通知-等待买家付款 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; case AlipayTradeStatus.Success: // 支付成功 _logger.LogInformation("扫码支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; default: return AlipayNotifyResult.Failure; } } catch (AlipayException ex) { _logger.LogWarning("出现异常: " + ex.Message); return AlipayNotifyResult.Failure; } } /// /// APP支付异步通知 /// [Route("apppay")] [HttpPost] public async Task AppPay() { try { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); switch (notify.TradeStatus) { case AlipayTradeStatus.Success: // 支付成功 _logger.LogInformation("APP支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; case AlipayTradeStatus.Closed: // 交易关闭 _logger.LogInformation("APP支付异步通知-未付款交易超时关闭,或支付完成后全额退款 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; case AlipayTradeStatus.Finished: // 交易完结 _logger.LogInformation("APP支付异步通知-交易结束,不可退款 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; default: return AlipayNotifyResult.Failure; } } catch (AlipayException ex) { _logger.LogWarning("出现异常: " + ex.Message); return AlipayNotifyResult.Failure; } } /// /// 电脑网站支付异步通知 /// [Route("pagepay")] [HttpPost] public async Task PagePay() { try { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); switch (notify.TradeStatus) { case AlipayTradeStatus.Success: // 支付成功 _logger.LogInformation("电脑网站支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; case AlipayTradeStatus.Closed: // 交易关闭 _logger.LogInformation("电脑网站支付异步通知-未付款交易超时关闭,或支付完成后全额退款 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; case AlipayTradeStatus.Finished: // 交易完结 _logger.LogInformation("电脑网站支付异步通知-交易结束,不可退款 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; default: return AlipayNotifyResult.Failure; } } catch (AlipayException ex) { _logger.LogWarning("出现异常: " + ex.Message); return AlipayNotifyResult.Failure; } } /// /// 手机网站支付异步通知 /// [Route("wappay")] [HttpPost] public async Task WapPay() { try { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); switch (notify.TradeStatus) { case AlipayTradeStatus.Success: // 支付成功 _logger.LogInformation("手机网站支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; case AlipayTradeStatus.Closed: // 交易关闭 _logger.LogInformation("手机网站支付异步通知-未付款交易超时关闭,或支付完成后全额退款 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; case AlipayTradeStatus.Finished: // 交易完结 _logger.LogInformation("手机网站支付异步通知-交易结束,不可退款 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; default: return AlipayNotifyResult.Failure; } } catch (AlipayException ex) { _logger.LogWarning("出现异常: " + ex.Message); return AlipayNotifyResult.Failure; } } /// /// 交易关闭异步通知 /// [Route("close")] [HttpPost] public async Task Close() { try { var notify = await _client.CertificateExecuteAsync(Request, _optionsAccessor.Value.Alipay); if (notify.TradeStatus == AlipayTradeStatus.Closed) { _logger.LogInformation("交易关闭异步通知 => OutTradeNo: " + notify.OutTradeNo); return AlipayNotifyResult.Success; } return AlipayNotifyResult.Failure; } catch (AlipayException ex) { _logger.LogWarning("出现异常: " + ex.Message); return AlipayNotifyResult.Failure; } } } }