WxPayNotify.php 3.62 KB
<?php

namespace WebPlugin\Pay\weixin\lib;
use WebPlugin\PhpLog;

/**
 * 
 * 回调基础类
 * @author widyhu
 *
 */
class WxPayNotify extends WxPayNotifyReply
{
    // 向ERP提交订单状态有关接口调用日志和更新订单状态有关接口调用日志
    const ORDER_STATUS_LOG = '/Data/logs/pc_pay/order_status';
    // 日志等级,2表示记录信息等级的日志
    const LOG_LEVEL = 2;

    /**
     * 
     * 回调入口
     * @param bool $needSign  是否需要签名输出
     */
    final public function Handle($needSign = true)
    {
        // 初始化日志
        $log = new PhpLog(self::ORDER_STATUS_LOG, 'PRC', self::LOG_LEVEL);
        $log->LogInfo('begin WxPayNotify->Handle');

        $msg = "OK";
        //当返回false的时候,表示notify中调用NotifyCallBack回调失败获取签名校验失败,此时直接回复失败
        $result = WxPayApi::notify(array($this, 'NotifyCallBack'), $msg);
        $log->LogInfo(var_export($result, true));
        if ($result == false) {
            $log->LogInfo('===微信扫码支付Handle失败===');
            $this->SetReturn_code("FAIL");
            $this->SetReturn_msg($msg);
            $this->ReplyNotify(false);
            return;
        } else {
            $log->LogInfo('===微信扫码支付Handle成功===');
            //该分支在成功回调到NotifyCallBack方法,处理完成之后流程
            $this->SetReturn_code("SUCCESS");
            $this->SetReturn_msg("OK");
        }
        $this->ReplyNotify($needSign);
    }

    /**
     * 
     * 回调方法入口,子类可重写该方法
     * 注意:
     * 1、微信回调超时时间为2s,建议用户使用异步处理流程,确认成功之后立刻回复微信服务器
     * 2、微信服务器在调用失败或者接到回包为非确认包的时候,会发起重试,需确保你的回调是可以重入
     * @param array $data 回调解释出的参数
     * @param string $msg 如果回调处理失败,可以将错误信息输出到该方法
     * @return true回调出来完成不需要继续回调,false回调处理未完成需要继续回调
     */
    public function NotifyProcess($data, &$msg)
    {
        //TODO 用户基础该类之后需要重写该方法,成功的时候返回true,失败返回false
        return true;
    }

    /**
     * 
     * notify回调方法,该方法中需要赋值需要输出的参数,不可重写
     * @param array $data
     * @return true回调出来完成不需要继续回调,false回调处理未完成需要继续回调
     */
    final public function NotifyCallBack($data)
    {
        // 初始化日志
        $log = new PhpLog(self::ORDER_STATUS_LOG, 'PRC', self::LOG_LEVEL);
        $log->LogInfo('begin WxPayNotify->NotifyCallBack');
        $log->LogInfo(var_export($data, true));

        $msg = "OK";
        $result = $this->NotifyProcess($data, $msg);

        if ($result == true) {
            $log->LogInfo('===微信支付NotifyCallBack成功===');
            $this->SetReturn_code("SUCCESS");
            $this->SetReturn_msg("OK");
        } else {
            $log->LogInfo('===微信支付NotifyCallBack失败===');
            $this->SetReturn_code("FAIL");
            $this->SetReturn_msg($msg);
        }
        return $result;
    }

    /**
     * 
     * 回复通知
     * @param bool $needSign 是否需要签名输出
     */
    final private function ReplyNotify($needSign = true)
    {
        //如果需要签名
        if ($needSign == true &&
            $this->GetReturn_code() == "SUCCESS") {
            $this->SetSign();
        }
        WxpayApi::replyNotify($this->ToXml());
    }

}