AlipayNotifyController.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  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 IAlipayNotifyClient _client;
  14. private readonly IOptions<PaylinkOptions> _optionsAccessor;
  15. public AlipayNotifyController(ILogger<AlipayNotifyController> logger, IAlipayNotifyClient client, IOptions<PaylinkOptions> 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.Alipay);
  38. return AlipayNotifyResult.Success;
  39. }
  40. // 第三方应用授权取消消息
  41. case "alipay.open.auth.appauth.cancelled":
  42. {
  43. var notify = await _client.CertificateExecuteAsync<AlipayOpenAuthAppauthCancelledNotify>(Request, _optionsAccessor.Value.Alipay);
  44. return AlipayNotifyResult.Success;
  45. }
  46. // 用户授权取消消息
  47. case "alipay.open.auth.userauth.cancelled":
  48. {
  49. var notify = await _client.CertificateExecuteAsync<AlipayOpenAuthUserauthCancelledNotify>(Request, _optionsAccessor.Value.Alipay);
  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.Alipay);
  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.Alipay);
  62. return AlipayNotifyResult.Success;
  63. }
  64. // 收单退款冲退完成通知
  65. case "alipay.trade.refund.depositback.completed":
  66. {
  67. var notify = await _client.CertificateExecuteAsync<AlipayTradeRefundDepositbackCompletedNotify>(Request, _optionsAccessor.Value.Alipay);
  68. return AlipayNotifyResult.Success;
  69. }
  70. // 收单资金结算到银行账户,结算退票的异步通知
  71. case "alipay.trade.settle.dishonoured":
  72. {
  73. var notify = await _client.CertificateExecuteAsync<AlipayTradeSettleDishonouredNotify>(Request, _optionsAccessor.Value.Alipay);
  74. return AlipayNotifyResult.Success;
  75. }
  76. // 收单资金结算到银行账户,结算失败的异步通知
  77. case "alipay.trade.settle.fail":
  78. {
  79. var notify = await _client.CertificateExecuteAsync<AlipayTradeSettleFailNotify>(Request, _optionsAccessor.Value.Alipay);
  80. return AlipayNotifyResult.Success;
  81. }
  82. // 收单资金结算到银行账户,结算成功的异步通知
  83. case "alipay.trade.settle.success":
  84. {
  85. var notify = await _client.CertificateExecuteAsync<AlipayTradeSettleSuccessNotify>(Request, _optionsAccessor.Value.Alipay);
  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.Alipay);
  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.Alipay);
  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.Alipay);
  142. switch (notify.TradeStatus)
  143. {
  144. case AlipayTradeStatus.Success: // 支付成功
  145. _logger.LogInformation("APP支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo);
  146. return AlipayNotifyResult.Success;
  147. case AlipayTradeStatus.Closed: // 交易关闭
  148. _logger.LogInformation("APP支付异步通知-未付款交易超时关闭,或支付完成后全额退款 => OutTradeNo: " + notify.OutTradeNo);
  149. return AlipayNotifyResult.Success;
  150. case AlipayTradeStatus.Finished: // 交易完结
  151. _logger.LogInformation("APP支付异步通知-交易结束,不可退款 => OutTradeNo: " + notify.OutTradeNo);
  152. return AlipayNotifyResult.Success;
  153. default:
  154. return AlipayNotifyResult.Failure;
  155. }
  156. }
  157. catch (AlipayException ex)
  158. {
  159. _logger.LogWarning("出现异常: " + ex.Message);
  160. return AlipayNotifyResult.Failure;
  161. }
  162. }
  163. /// <summary>
  164. /// 电脑网站支付异步通知
  165. /// </summary>
  166. [Route("pagepay")]
  167. [HttpPost]
  168. public async Task<IActionResult> PagePay()
  169. {
  170. try
  171. {
  172. var notify = await _client.CertificateExecuteAsync<AlipayTradePagePayNotify>(Request, _optionsAccessor.Value.Alipay);
  173. switch (notify.TradeStatus)
  174. {
  175. case AlipayTradeStatus.Success: // 支付成功
  176. _logger.LogInformation("电脑网站支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo);
  177. return AlipayNotifyResult.Success;
  178. case AlipayTradeStatus.Closed: // 交易关闭
  179. _logger.LogInformation("电脑网站支付异步通知-未付款交易超时关闭,或支付完成后全额退款 => OutTradeNo: " + notify.OutTradeNo);
  180. return AlipayNotifyResult.Success;
  181. case AlipayTradeStatus.Finished: // 交易完结
  182. _logger.LogInformation("电脑网站支付异步通知-交易结束,不可退款 => OutTradeNo: " + notify.OutTradeNo);
  183. return AlipayNotifyResult.Success;
  184. default:
  185. return AlipayNotifyResult.Failure;
  186. }
  187. }
  188. catch (AlipayException ex)
  189. {
  190. _logger.LogWarning("出现异常: " + ex.Message);
  191. return AlipayNotifyResult.Failure;
  192. }
  193. }
  194. /// <summary>
  195. /// 手机网站支付异步通知
  196. /// </summary>
  197. [Route("wappay")]
  198. [HttpPost]
  199. public async Task<IActionResult> WapPay()
  200. {
  201. try
  202. {
  203. var notify = await _client.CertificateExecuteAsync<AlipayTradeWapPayNotify>(Request, _optionsAccessor.Value.Alipay);
  204. switch (notify.TradeStatus)
  205. {
  206. case AlipayTradeStatus.Success: // 支付成功
  207. _logger.LogInformation("手机网站支付异步通知-交易支付成功 => OutTradeNo: " + notify.OutTradeNo);
  208. return AlipayNotifyResult.Success;
  209. case AlipayTradeStatus.Closed: // 交易关闭
  210. _logger.LogInformation("手机网站支付异步通知-未付款交易超时关闭,或支付完成后全额退款 => OutTradeNo: " + notify.OutTradeNo);
  211. return AlipayNotifyResult.Success;
  212. case AlipayTradeStatus.Finished: // 交易完结
  213. _logger.LogInformation("手机网站支付异步通知-交易结束,不可退款 => OutTradeNo: " + notify.OutTradeNo);
  214. return AlipayNotifyResult.Success;
  215. default:
  216. return AlipayNotifyResult.Failure;
  217. }
  218. }
  219. catch (AlipayException ex)
  220. {
  221. _logger.LogWarning("出现异常: " + ex.Message);
  222. return AlipayNotifyResult.Failure;
  223. }
  224. }
  225. /// <summary>
  226. /// 交易关闭异步通知
  227. /// </summary>
  228. [Route("close")]
  229. [HttpPost]
  230. public async Task<IActionResult> Close()
  231. {
  232. try
  233. {
  234. var notify = await _client.CertificateExecuteAsync<AlipayTradeCloseNotify>(Request, _optionsAccessor.Value.Alipay);
  235. if (notify.TradeStatus == AlipayTradeStatus.Closed)
  236. {
  237. _logger.LogInformation("交易关闭异步通知 => OutTradeNo: " + notify.OutTradeNo);
  238. return AlipayNotifyResult.Success;
  239. }
  240. return AlipayNotifyResult.Failure;
  241. }
  242. catch (AlipayException ex)
  243. {
  244. _logger.LogWarning("出现异常: " + ex.Message);
  245. return AlipayNotifyResult.Failure;
  246. }
  247. }
  248. }
  249. }