
- 添加 LinSuoKa 类实现临时锁卡功能 - 优化卡密订单关联逻辑,处理状态为 4 的订单- 新增 redis 记录订单详情,用于限单和退款处理 - 修改 Qiling 类中的签名生成逻辑 - 更新 Test 控制器中的 test_ts 方法,增加对不同订单表的处理
154 lines
4.0 KiB
PHP
154 lines
4.0 KiB
PHP
<?php
|
|
|
|
namespace app\channel\service\system;
|
|
|
|
#模板
|
|
class Mgdy extends Core
|
|
{
|
|
protected $host = ''; // 主机,不设置,后台
|
|
protected $mid = ''; // 商户id
|
|
protected $token = ''; // 密钥
|
|
protected $api = '';
|
|
//话费直充
|
|
|
|
# 通用卡密购买,命名规范 渠道加卡的首字母_cardbuy 骏卡xxka jkxxk_cardbuy
|
|
# cardbuy为通用写法
|
|
public function dy($param)
|
|
{
|
|
$check = array
|
|
(
|
|
'account' => 'dyAccount',
|
|
'cash'=>'amount'
|
|
);
|
|
$this->api='api/order/v1/submit';
|
|
return $this->submit($param, $check);
|
|
}
|
|
|
|
public function common($param)
|
|
{
|
|
$check = array
|
|
(
|
|
'account' => 'dyAccount',
|
|
'cash'=>'amount'
|
|
);
|
|
$this->api='api/order/v1/submit';
|
|
return $this->submit($param, $check);
|
|
}
|
|
|
|
|
|
|
|
# 通知处理 主要返回状态 2是成功 3是失败
|
|
public function notify($data)
|
|
{
|
|
$result = array();
|
|
$result['cash'] = 1;
|
|
$result['status'] = 4;
|
|
#以上基本不要变
|
|
|
|
|
|
if ($data['status'] == 'SUCCESS') {
|
|
$result['status'] = 2;
|
|
} else if($data['status'] == 'FAILED') {
|
|
$result['status'] = 3;
|
|
}else {
|
|
$result['status'] = 4;
|
|
}
|
|
|
|
#以下处理逻辑可以自由
|
|
|
|
|
|
$result['yes'] = 'ok'; //响应给上游的数据
|
|
|
|
$result['data'] = $data;
|
|
|
|
return $result;
|
|
}
|
|
|
|
# 数据响应格式处理
|
|
public function response($data)
|
|
{
|
|
$log['type'] = 'response';
|
|
$log['data'] = $data;
|
|
$log['config'] = $this->data;
|
|
$this->log($log);
|
|
|
|
#以上不要做任何变动
|
|
|
|
|
|
|
|
$array = $this->json_decode($data); //响应数据为json
|
|
#如果响应为XML格式
|
|
//
|
|
|
|
if (!$array) {
|
|
$msg = 'error';
|
|
} elseif (isset($array['code']) && $array['code']=='200') { //修改判断逻辑为确定提交成功即可
|
|
# 正确
|
|
$msg = 'ok';
|
|
|
|
} else {
|
|
# 错误
|
|
$msg = $array['msg'] ?? 'error'; //前面message根据响应内容改成对应的错误提示
|
|
}
|
|
|
|
return array
|
|
(
|
|
'msg' => $msg,
|
|
'data' => $data,
|
|
'array' => $array,
|
|
);
|
|
}
|
|
|
|
|
|
# 提交数据
|
|
private function submit($param, $check)
|
|
{
|
|
#提交处理
|
|
$param = $this->param($param, $check);
|
|
if (is_string($param) || (is_array($param) && $param['status'] == 1)) {
|
|
return $param;
|
|
}
|
|
$request = $param['detail']; //上面替换剩下的
|
|
#结束初步
|
|
$request['appId']=$this->mid; //
|
|
$request['outTradeNo']=$param['order']; //我方系统订单号
|
|
$request['type']=$this->getGid($param['cash']); //此方法为根据面值获取产品id,如无需可注释
|
|
$request['asyncUrl']=$this->getNotify($param['order'], 1); //回调方法默认不用改
|
|
|
|
|
|
|
|
|
|
$request['nonceStr']=rand(100000,999999);
|
|
// unset($request['cash']);
|
|
$request['sign'] = $this->_sign($request);
|
|
$url = $this->host . $this->api; //组装地址
|
|
|
|
#该系统提交写法:
|
|
|
|
$response = $this->curl('post', $url, $request);
|
|
$response = $this->response($response);
|
|
$channel_order_id = '';
|
|
|
|
#如果出现响应有上游订单号,可以如下
|
|
if (isset($response["array"]['data']['orderNo'])) {
|
|
$channel_order_id = $response["array"]['data']['orderNo'];
|
|
}
|
|
|
|
$this->create($param['order'], $channel_order_id, $param['merchant_order'], $param['cash'], $url, $request, $response, 1, $param['account']);
|
|
return $response['msg'];
|
|
}
|
|
|
|
private function _sign($request)
|
|
{
|
|
// unset($request['cash']);
|
|
ksort($request);
|
|
$str='';
|
|
foreach($request as $k=>$v){
|
|
$str.=$k.'='.$v.'&';
|
|
}
|
|
$str=$str.'key='.$this->token;
|
|
// var_dump($str);die;
|
|
|
|
return strtoupper(md5($str));
|
|
}
|
|
} |