AlipayNotify.php 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace crmeb\services\alipay;
  12. use Payment\Contracts\IPayNotify;
  13. use think\exception\ValidateException;
  14. use think\facade\Log;
  15. class AlipayNotify implements IPayNotify
  16. {
  17. private $type;
  18. public function __construct($type)
  19. {
  20. $this->type = $type;
  21. }
  22. /**
  23. * 处理支付宝支付回调。
  24. *
  25. * 本函数负责接收并处理支付宝支付回调通知。它首先验证交易状态是否为成功或完成,
  26. * 如果验证失败,则抛出一个异常表明交易未支付。如果验证成功,它将触发一个事件来处理支付成功的逻辑。
  27. *
  28. * @param string $channel 支付渠道,此处固定为支付宝。
  29. * @param string $notifyType 通知类型,指示回调的具体类型。
  30. * @param string $notifyWay 通知方式,指示回调的通知途径。
  31. * @param array $notifyData 通知数据,包含支付宝返回的所有回调信息。
  32. * @return bool 返回处理结果,true表示处理成功,false表示处理失败。
  33. * @throws ValidateException 如果交易状态不是TRADE_SUCCESS或TRADE_FINISHED,则抛出此异常。
  34. */
  35. public function handle(string $channel, string $notifyType, string $notifyWay, array $notifyData)
  36. {
  37. // 记录回调数据到日志,用于后续的调试和审计。
  38. Log::info('支付宝支付回调 handle:' . var_export($notifyData, 1));
  39. // 验证交易状态是否为成功或完成,如果不是,则抛出异常。
  40. if (!in_array($notifyData['trade_status'], ['TRADE_SUCCESS', 'TRADE_FINISHED']))
  41. throw new ValidateException('未支付');
  42. try {
  43. // 触发支付成功事件,传入订单号和通知数据。
  44. Log::info('支付宝支付成功回调执行队列 handle:' . var_export([$this->type,$notifyData],1));
  45. event('pay_success_' . $this->type, ['order_sn' => $notifyData['out_trade_no'], 'data' => $notifyData]);
  46. return true;
  47. } catch (\Exception$e) {
  48. // 记录处理回调失败的原因到日志。
  49. Log::info('支付宝支付回调失败handle:' . $e->getMessage());
  50. }
  51. // 如果处理过程中发生异常或错误,则返回false。
  52. return false;
  53. }
  54. }