40 lines
1.3 KiB
PHP
40 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace App\ServicePay\TransCard;
|
|
|
|
use App\Models\Order;
|
|
|
|
class FeilvbinCard extends BaseCard
|
|
{
|
|
public function message($msg)
|
|
{
|
|
$this->msg = $msg;
|
|
$pattern= '/(?<=P)\d+\.\d{2}|\d{2}-\d{2}-\d{2}\s\d{2}:\d{2}\s\w{2}|(?<=\s)\d{4}(?=\.)|(?<=No.\s)\d{10,}(?=\.)/';
|
|
$match_num = preg_match_all($pattern, $this->msg, $matches, PREG_PATTERN_ORDER);
|
|
if ($match_num != false && $match_num > 0 && $matches[0]) {
|
|
$this->orderInfo = [
|
|
'pay_money' => $matches[0][0],
|
|
'from_card' => $matches[0][1],
|
|
'sms_date' => $matches[0][3],
|
|
'order_number' => $matches[0][4],
|
|
];
|
|
}
|
|
}
|
|
|
|
//获取订单信息
|
|
public function orderInfo($requestArr)
|
|
{
|
|
$showInfo = $this->showInfo();
|
|
$ewm_account = $showInfo['from_card'];
|
|
$order_money = $showInfo['pay_money'];
|
|
$order_money = number_format($order_money, 2, '.', '');
|
|
//查找未支付的订单
|
|
$t = date('Y-m-d H:i:s');
|
|
return Order::where('order_at', '<', $t)
|
|
->where('order_money', $order_money)
|
|
->whereRaw('substr(ewm_account,-4,4)=?', [$ewm_account])
|
|
// ->whereIn('status', [0, 2])
|
|
->orderBy('id', 'desc')->first();
|
|
}
|
|
}
|