支付宝支付回调,回调日志记录

 1、支付报支付回调方法

public function aliPayNotify()
    {
        try {
            $app = PayService::alipay();
            $collect             = $app->verify();
            $collectData         = $collect->all();//获取支付宝回调参数
          
            $this->writeAliPayLog($collectData, true);
            
            if ($collectData['trade_status'] != 'TRADE_SUCCESS' &&                     
                $collectData['trade_status'] != 'TRADE_FINISHED') {
                return;
            }
           
            //订单处理
            

        } catch (InvalidSignException $e) {
            $this->writeAliPayLog($e->raw, false);
            echo "fail";
        }
    }
    

2、日志写入方法

private function writeAliPayLog($data, $success = true)
    {
        $logStr = "-----[APP]-ASYN-异步序列号-" . $this->indexNo . $this->dateTime . "-异步开始->BEGIN:-------" . "\n";
        if ($success === false) {
            $logStr = "     ->APP-ASYN------验签是否通过:NO\n";
            if (count($data) > 0 && array_key_exists("trade_no", $data)) {
                $logStr .= "     ->APP-DATA-LIST-支付宝交易号:" . $data["trade_no"] . "\n";
                $logStr .= "     ->APP-DATA-LIST-商户订单号:" . $data["out_trade_no"] . "\n";
            } else {
                $logStr .= "     ->APP-ASYN------非法请求:拒绝响应\n";
            }
        } else {
            $logStr .= "     ->APP-ASYN------验签是否通过:OK\n";
            // 写入支付完成时间
            $logStr .= "     ->APP-DATA-LIST-交易时间:" . $this->payTime . "\n";
            $logStr .= "     ->APP-DATA-LIST-商户订单号:" . $data["out_trade_no"] . "\n";
            $logStr .= "     ->APP-DATA-LIST-买家支付宝账号:" . $data["buyer_logon_id"] . "\n";
            $logStr .= "     ->APP-DATA-LIST-交易金额:" . $data["total_amount"] . "\n";
            $logStr .= "     ->APP-DATA-LIST-实收金额:" . $data["receipt_amount"] . "\n";
            $logStr .= "     ->APP-DATA-LIST-买家付款的金额:" . $data["buyer_pay_amount"] . "\n";
            $logStr .= "     ->APP-DATA-LIST-支付宝交易号:" . $data["trade_no"] . "\n";
//            $logStr .= "     ->APP-DATA-LIST-交易状态:" . $data["return_code"] . "\n";
            $logStr .= "     ->APP-DATA-LIST-交易状态:" . $data["trade_status"] . "\n";
            //$logStr .= "     ->APP-DATA-LIST-设备类型:" . $data["trade_type"] . "\n";
        }

        $logStr .= " -----[APP]-ASYN-异步序列号-" . $this->indexNo . "-异步完成->END-----------\n";
        file_put_contents($this->aliPayNotifyPath, $logStr, FILE_APPEND);//this->aliPayNotifyPath日志地址
    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue中处理支付的付款回调可以按照以下步骤进行: 1. 在Vue项目的前端页面中,创建一个用于接收支付回调的URL。这个URL将用于接收支付服务器发送的回调请求。 2. 在Vue项目的后端服务器中,创建一个用于处理支付回调的接口。这个接口将接收前端页面发送过来的回调请求,并进行验证和处理。 3. 在支付开放平台中,配置支付回调的URL。在配置中,将前面创建的URL作为回调地址。 4. 在后端接口中,验证支付回调请求的合法性。可以使用支付提供的SDK或工具包进行验证,确保回调请求是由支付服务器发送的,并且数据没有被篡改。 5. 根据回调请求的结果,进行相应的处理。例如,更新订单状态、生成交易记录等。 下面是一个示例代码片段,展示了如何在Vue中处理支付的付款回调: ```javascript // 前端页面中的代码 methods: { handleAlipayCallback() { // 发送回调请求到后端接口 axios.post('/api/alipay/callback', { /* 回调请求数据 */ }) .then(response => { // 处理回调请求的响应 console.log(response.data); }) .catch(error => { // 处理错误 console.error(error); }); } } // 后端接口中的代码 app.post('/api/alipay/callback', (req, res) => { // 验证回调请求的合法性 const isValid = verifyAlipayCallback(req.body); if (isValid) { // 处理回调请求 handleAlipayCallback(req.body); // 返回处理结果 res.send('success'); } else { // 回调请求不合法,返回错误信息 res.status(403).send('Invalid callback request'); } }); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值