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