You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

111 lines
3.8 KiB
PHP

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<?php
namespace Admin\Controller;
class FinanceCompareController extends ThinkController
{
public $zfb = [1];//官方支付宝渠道id
public $wx = [2,3];//微信渠道id
public $ybzf = [17];//易宝渠道id
public function add()
{
$this->display();
# code...
}
public function creatCompare()
{
# code...
}
public function compareData()
{
// $data = I('POST.');
$keys = ["支付订单号","实付金额"];
$compare_id = 1;
$pay_way = 1;//1支付宝 2微信 17易宝
$data = [
["支付订单号"=> "SP_202003231152197Lhd_test","实付金额"=>0.01],
["支付订单号"=> "SP_20200325103203fBPI_test","实付金额"=>0.01],
["支付订单号"=> "SP_20200325102118dbIy_test","实付金额"=>0.01],
["支付订单号"=> "SP_20200325102110Dpga_test","实付金额"=>0.01],
["支付订单号"=> "PF_20200225170537PpOt","实付金额"=>1]
];
//过滤数据
$sp=[];
$pf=[];
$er=[];
foreach($data as $k=>$v){
$pay_where = substr($v[$keys[0]], 0, 2);
$tmp = [
"pt_pay_amount"=>$v[$keys[1]],
"diff_money"=>$v[$keys[1]],
"sj_pay_amount"=>0,
"type"=>3,
"pay_order_number"=>$v[$keys[0]],
"compare_id"=>$compare_id,
"pay_way"=>$pay_way,
"is_read"=>0
];
if($pay_where == 'SP'){
$sp[$v[$keys[0]]] = $tmp;
}elseif($pay_where == 'PF'){
$pf[$v[$keys[0]]] = $tmp;
}else{
$er[$v[$keys[0]]] = $tmp;
}
}
//判断游戏流水
if(count($sp) > 0){
$keys = implode(",",array_keys($sp));
$where = ["pay_order_number"=>["in",$keys]];
$sres = M("Spend","tab_")->field("pay_order_number,pay_amount,pay_status,pay_way")->where($where)->select();
if($sres){
$this->setDiffData($sres,$sp);
}
}
dump($sres);
}
protected function setDiffData($dbres,$ydata)
{
//type 1:金额不符 2商家数据缺失 3:平台数据缺失 4:状态不符5:渠道不符
foreach ($dbres as $k => $v) {
if(array_key_exists($v['pay_order_number'],$ydata)){
//存在
$flag = true;
$ydata[$v['pay_order_number']]['sj_pay_amount'] = $v['pay_amount'];
$ydata[$v['pay_order_number']]['diff_money'] = abs($ydata[$v['pay_order_number']]['pt_pay_amount']-$v['pay_amount']);
$way = $ydata[$v['pay_order_number']]['pay_way'];
if ($way == 1) {
$checkarr = $this->$zfb;
}elseif($way == 2){
$checkarr = $this->$wx;
}elseif($way == 3){
$checkarr = $this->$ybzf;
}
if(!in_array($way,$checkarr)){//渠道不符
$ydata[$v['pay_order_number']]['type'] = 5;
$flag = false;
}
if($ydata[$v['pay_order_number']]['pt_pay_amount'] != $v['pay_amount']){//金额不符
$ydata[$v['pay_order_number']]['type'] = 1;
$flag = false;
}
if($v['pay_status'] != 1){//状态不符合
$ydata[$v['pay_order_number']]['type'] = 4;
$ydata[$v['pay_order_number']]['diff_money'] = $v['pay_amount'];
$flag = false;
}
if($flag){
$ydata[$v['pay_order_number']]['type'] = 0;
}
}
}
dd($ydata);
# code...
}
}