AlipayNotifyController.cs 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. using System.Threading.Tasks;
  2. using Essensoft.Paylink.Alipay;
  3. using Essensoft.Paylink.Alipay.Notify;
  4. using Microsoft.AspNetCore.Mvc;
  5. using Microsoft.Extensions.Logging;
  6. using Microsoft.Extensions.Options;
  7. namespace WebApplicationSample.Controllers
  8. {
  9. [Route("alipay/notify")]
  10. public class AlipayNotifyController : Controller
  11. {
  12. private readonly ILogger<AlipayNotifyController> _logger;
  13. private readonly IAlipayClient _client;
  14. private readonly IOptions<AlipayOptions> _optionsAccessor;
  15. public AlipayNotifyController(ILogger<AlipayNotifyController> logger, IAlipayClient client, IOptions<AlipayOptions> optionsAccessor)
  16. {
  17. _logger = logger;
  18. _client = client;
  19. _optionsAccessor = optionsAccessor;
  20. }
  21. /// <summary>
  22. /// 应用网关
  23. /// </summary>
  24. /// <returns></returns>
  25. [Route("gateway")]
  26. [HttpPost]
  27. public async Task<IActionResult> Gateway()
  28. {
  29. try
  30. {
  31. var msg_method = Request.Form["msg_method"].ToString();
  32. switch (msg_method)
  33. {
  34. // 资金单据状态变更通知
  35. case "alipay.fund.trans.order.changed":
  36. {
  37. var notify = await _client.CertificateExecuteAsync<AlipayFundTransOrderChangedNotify>(Request, _optionsAccessor.Value);
  38. return AlipayNotifyResult.Success;
  39. }
  40. // 第三方应用授权取消消息
  41. case "alipay.open.auth.appauth.cancelled":
  42. {
  43. var notify = await _client.CertificateExecuteAsync<AlipayOpenAuthAppauthCancelledNotify>(Request, _optionsAccessor.Value);
  44. return AlipayNotifyResult.Success;
  45. }
  46. // 用户授权取消消息
  47. case "alipay.open.auth.userauth.cancelled":
  48. {
  49. var notify = await _client.CertificateExecuteAsync<AlipayOpenAuthUserauthCancelledNotify>(Request, _optionsAccessor.Value);
  50. return AlipayNotifyResult.Success;
  51. }
  52. // 小程序审核通过通知
  53. case "alipay.open.mini.version.audit.passed":
  54. {
  55. var notify = await _client.CertificateExecuteAsync<AlipayOpenMiniVersionAuditPassedNotify>(Request, _optionsAccessor.Value);
  56. return AlipayNotifyResult.Success;
  57. }
  58. // 小程序审核驳回通知
  59. case "alipay.open.mini.version.audit.rejected":
  60. {
  61. var notify = await _client.CertificateExecuteAsync<AlipayOpenMiniVersionAuditRejectedNotify>(Request, _optionsAccessor.Value);
  62. return AlipayNotifyResult.Success;
  63. }
  64. // 收单退款冲退完成通知
  65. case "alipay.trade.refund.depositback.completed":
  66. {
  67. var notify = await _client.CertificateExecuteAsync<AlipayTradeRefundDepositbackCompletedNotify>(Request, _optionsAccessor.Value);
  68. return AlipayNotifyResult.Success;
  69. }
  70. // 收单资金结算到银行账户,结算退票的异步通知
  71. case "alipay.trade.settle.dishonoured":
  72. {
  73. var notify = await _client.CertificateExecuteAsync<AlipayTradeSettleDishonouredNotify>(Request, _optionsAccessor.Value);
  74. return AlipayNotifyResult.Success;
  75. }
  76. // 收单资金结算到银行账户,结算失败的异步通知
  77. case "alipay.trade.settle.fail":
  78. {
  79. var notify = await _client.CertificateExecuteAsync<AlipayTradeSettleFailNotify>(Request, _optionsAccessor.Value);
  80. return AlipayNotifyResult.Success;
  81. }
  82. // 收单资金结算到银行账户,结算成功的异步通知
  83. case "alipay.trade.settle.success":
  84. {
  85. var notify = await _client.CertificateExecuteAsync<AlipayTradeSettleSuccessNotify>(Request, _optionsAccessor.Value);
  86. return AlipayNotifyResult.Success;
  87. }
  88. // 身份认证记录消息
  89. case "alipay.user.certify.open.notify.completed":
  90. {
  91. var notify = await _client.CertificateExecuteAsync<AlipayUserCertifyOpenNotifyCompletedNotify>(Request, _optionsAccessor.Value);
  92. return AlipayNotifyResult.Success;
  93. }
  94. default:
  95. return AlipayNotifyResult.Failure;
  96. }
  97. }
  98. catch (AlipayException ex)
  99. {
  100. _logger.LogWarning("出现异常: " + ex.Message);
  101. return AlipayNotifyResult.Failure;
  102. }
  103. }
  104. /// <summary>
  105. /// 扫码支付异步通知
  106. /// </summary>
  107. [Route("precreate")]
  108. [HttpPost]
  109. public async Task<IActionResult> Precreate()
  110. {
  111. try
  112. {
  113. var notify = await _client.CertificateExecuteAsync<AlipayTradePrecreateNotify>(Request, _optionsAccessor.Value);
  114. switch (notify.TradeStatus)
  115. {
  116. case AlipayTradeStatus.Wait: // 等待付款
  117. _logger.LogInformation("扫码支付异步通知-等待买家付款 => OutTradeNo: " + notify.OutTradeNo);
  118. return AlipayNotifyResult.Success;
  119. case AlipayTradeStatus.Success: // 支付成功
  120. _logger.LogInformation("扫码支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo);
  121. return AlipayNotifyResult.Success;
  122. default:
  123. return AlipayNotifyResult.Failure;
  124. }
  125. }
  126. catch (AlipayException ex)
  127. {
  128. _logger.LogWarning("出现异常: " + ex.Message);
  129. return AlipayNotifyResult.Failure;
  130. }
  131. }
  132. /// <summary>
  133. /// APP支付异步通知
  134. /// </summary>
  135. [Route("apppay")]
  136. [HttpPost]
  137. public async Task<IActionResult> AppPay()
  138. {
  139. try
  140. {
  141. var notify = await _client.CertificateExecuteAsync<AlipayTradeAppPayNotify>(Request, _optionsAccessor.Value);
  142. if (notify.TradeStatus == AlipayTradeStatus.Success)
  143. {
  144. _logger.LogInformation("APP支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo);
  145. return AlipayNotifyResult.Success;
  146. }
  147. return AlipayNotifyResult.Failure;
  148. }
  149. catch (AlipayException ex)
  150. {
  151. _logger.LogWarning("出现异常: " + ex.Message);
  152. return AlipayNotifyResult.Failure;
  153. }
  154. }
  155. /// <summary>
  156. /// 电脑网站支付异步通知
  157. /// </summary>
  158. [Route("pagepay")]
  159. [HttpPost]
  160. public async Task<IActionResult> PagePay()
  161. {
  162. try
  163. {
  164. var notify = await _client.CertificateExecuteAsync<AlipayTradePagePayNotify>(Request, _optionsAccessor.Value);
  165. if (notify.TradeStatus == AlipayTradeStatus.Success)
  166. {
  167. _logger.LogInformation("电脑网站支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo);
  168. return AlipayNotifyResult.Success;
  169. }
  170. return AlipayNotifyResult.Failure;
  171. }
  172. catch (AlipayException ex)
  173. {
  174. _logger.LogWarning("出现异常: " + ex.Message);
  175. return AlipayNotifyResult.Failure;
  176. }
  177. }
  178. /// <summary>
  179. /// 手机网站支付异步通知
  180. /// </summary>
  181. [Route("wappay")]
  182. [HttpPost]
  183. public async Task<IActionResult> WapPay()
  184. {
  185. try
  186. {
  187. var notify = await _client.CertificateExecuteAsync<AlipayTradeWapPayNotify>(Request, _optionsAccessor.Value);
  188. if (notify.TradeStatus == AlipayTradeStatus.Success)
  189. {
  190. _logger.LogInformation("手机网站支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo);
  191. return AlipayNotifyResult.Success;
  192. }
  193. return AlipayNotifyResult.Failure;
  194. }
  195. catch (AlipayException ex)
  196. {
  197. _logger.LogWarning("出现异常: " + ex.Message);
  198. return AlipayNotifyResult.Failure;
  199. }
  200. }
  201. /// <summary>
  202. /// 交易关闭异步通知
  203. /// </summary>
  204. [Route("close")]
  205. [HttpPost]
  206. public async Task<IActionResult> Close()
  207. {
  208. try
  209. {
  210. var notify = await _client.CertificateExecuteAsync<AlipayTradeCloseNotify>(Request, _optionsAccessor.Value);
  211. if (notify.TradeStatus == AlipayTradeStatus.Closed)
  212. {
  213. _logger.LogInformation("交易关闭异步通知 => OutTradeNo: " + notify.OutTradeNo);
  214. return AlipayNotifyResult.Success;
  215. }
  216. return AlipayNotifyResult.Failure;
  217. }
  218. catch (AlipayException ex)
  219. {
  220. _logger.LogWarning("出现异常: " + ex.Message);
  221. return AlipayNotifyResult.Failure;
  222. }
  223. }
  224. }
  225. }