274 lines
8.8 KiB
PHP
274 lines
8.8 KiB
PHP
<?php
|
|
|
|
namespace app\channel\service\system;
|
|
|
|
use app\merchant\service\OrderService;
|
|
use think\facade\Db;
|
|
|
|
class Zhongwangshuke extends Core
|
|
{
|
|
# 这几个可以后台设置
|
|
protected $host = '';
|
|
protected $mid = '';
|
|
protected $token = '';
|
|
protected $api = '';
|
|
|
|
# 中石油油卡充值 拼音来吧
|
|
public function zsycz($param)
|
|
{
|
|
$check = array
|
|
(
|
|
'card' => 'ChargeAccount',
|
|
'cash' => 'cash',
|
|
);
|
|
|
|
$this->api = 'Order/InsertV2';
|
|
return $this->submit($param, $check);
|
|
}
|
|
|
|
# 中石化油卡充值
|
|
public function zshcz($param)
|
|
{
|
|
$check = array
|
|
(
|
|
'card' => 'ChargeAccount',
|
|
'cash' => 'cash',
|
|
);
|
|
|
|
$this->api = 'Order/InsertV2';
|
|
return $this->submit($param, $check);
|
|
}
|
|
public function zwsk_cardbuy($param){
|
|
$check = array
|
|
(
|
|
'account' => 'ChargeAccount',
|
|
'cash' => 'cash',
|
|
);
|
|
|
|
$this->api = 'Order/InsertSiberianNitrariaFruitV2';
|
|
return $this->submit($param, $check,true);
|
|
}
|
|
public function carbuy($param){
|
|
$check = array
|
|
(
|
|
'card' => 'ChargeAccount',
|
|
'cash' => 'cash',
|
|
);
|
|
|
|
$this->api = 'Order/InsertSiberianNitrariaFruitV2';
|
|
return $this->submit($param, $check,true);
|
|
}
|
|
# 通用的充值
|
|
public function common($param)
|
|
{
|
|
$check = array
|
|
(
|
|
'account' => 'ChargeAccount',
|
|
'cash' => 'cash',
|
|
);
|
|
|
|
$this->api = 'Order/InsertV2';
|
|
return $this->submit($param, $check);
|
|
}
|
|
public function dhcz($param)
|
|
{
|
|
$check = array
|
|
(
|
|
'mobile' => 'ChargeAccount',
|
|
'cash' => 'cash',
|
|
);
|
|
|
|
$this->api = 'Order/InsertV2';
|
|
return $this->submit($param, $check);
|
|
}
|
|
|
|
# 通知处理 主要返回状态 2是成功 3是失败
|
|
public function notify($data)
|
|
{
|
|
//{"s_order":"Q202109255380106740389923","ChargeAccount":"15810090845","ProductCode":"PLM102924","BuyCount":"1","MOrderID":"Q202109255380106740389923","OrderID":"210925151001139000","State":"2","AppKey":"211395015","TimesTamp":"1632553929300","Sign":"287947FE75AE16A172FDB5B6D4D5D56F","ExtendParam":"{\"OfficialDes\":null,\"OfficialOrderID\":null,\"SellPrice\":190000}","ChargeMsg":""}
|
|
$request = $data;
|
|
$sign = $this->_sign($request, array('AppKey', 'TimesTamp', 'OrderID', 'MOrderID', 'State'));
|
|
if ($sign != $data['Sign']) {
|
|
return false;
|
|
}
|
|
$result = array();
|
|
$result['cash'] = 1;
|
|
if ($data['State'] == 2) {
|
|
$result['status'] = 2;
|
|
} elseif ($data['State'] == 3) {
|
|
$result['status'] = 3;
|
|
} else {
|
|
$result['status'] = 4;
|
|
}
|
|
|
|
if (isset($data['ExtendParam']) && is_string($data['ExtendParam']) && strstr($data['ExtendParam'], '{')) {
|
|
$data['ExtendParam'] = json_decode($data['ExtendParam'], true);
|
|
}
|
|
|
|
if (isset($data['ExtendParam']['OfficialOrderID']) && $data['ExtendParam']['OfficialOrderID']) {
|
|
# 错误信息
|
|
$msg = $data['msg'] = $result['msg'] = $data['ExtendParam']['OfficialOrderID'];
|
|
|
|
# 流水号
|
|
if (strstr($data['msg'], '订单号:')) {
|
|
$temp = explode('订单号:', $data['msg']);
|
|
$data['s_nubmer'] = $result['s_nubmer'] = $temp[1];
|
|
}
|
|
}
|
|
|
|
$result['yes'] = '{"Code":0}';
|
|
|
|
$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);
|
|
if (!$array) {
|
|
$msg = 'error';
|
|
} elseif (isset($array['Code']) && $array['Code'] == '999') {
|
|
# 正确
|
|
$msg = 'ok';
|
|
if (isset($array['ExtendParam'])&&isset($array['ExtendParam']['CardNumber'])) {
|
|
$msg = 'yescard';
|
|
$order=OrderService::instance()->get($array['Data']['MOrderID']);
|
|
$map=Db::name('product_map')->where(array('cid'=>$order['cid'],'pid'=>$order['pid'],'key'=>$order['product_key']))->find();
|
|
$cardlist = $array['ExtendParam'];
|
|
$cardno = $this->decrypt(json_decode($map['json_text'],true)['MemberPublicKey'],$cardlist['CardNumber'],json_decode($map['extra_param'],true)['private_key']);
|
|
$cardpwd = $this->decrypt(json_decode($map['json_text'],true)['MemberPublicKey'],$cardlist['CardPwd'],json_decode($map['extra_param'],true)['private_key']);
|
|
|
|
|
|
$array['kami'] = array
|
|
(
|
|
'cardno' => $cardno,
|
|
'cardpwd' => $cardpwd,
|
|
'expired' => $cardlist['CardDeadline'],
|
|
);
|
|
|
|
|
|
|
|
}
|
|
} else {
|
|
# 错误
|
|
$msg = isset($array['Msg']) ? $array['Msg'] : 'error';
|
|
}
|
|
|
|
return array
|
|
(
|
|
'msg' => $msg,
|
|
'data' => $data,
|
|
'array' => $array,
|
|
);
|
|
}
|
|
|
|
# 查询接口
|
|
public function query($order)
|
|
{
|
|
$this->api='Order/QueryV2';
|
|
$request['AppKey'] = $this->mid;
|
|
$request['TimesTamp'] = time();
|
|
$request['OrderID'] = $order['order_id'];
|
|
$request['Sign'] = $this->_sign($request, array('AppKey', 'TimesTamp', 'OrderID'));
|
|
$url = $this->host . $this->api;
|
|
$response = $this->curl('post', $url, $request);
|
|
|
|
|
|
// $log['type'] = 'query_response';
|
|
// $log['data'] = $response;
|
|
// $log['config'] = $this->data;
|
|
// $this->log($log);
|
|
|
|
// $array = $this->json_decode($response);
|
|
$array = $this->response($response);
|
|
|
|
$result = array();
|
|
$result['status'] = 4;
|
|
if ($array['array']['Code'] ==999) {
|
|
if($array['array']['Data']['OrderState'] == 2){
|
|
$result['status'] = 2;
|
|
}elseif ($array['array']['Data']['OrderState'] == 3){
|
|
$result['query_status'] = 2;
|
|
$result['status'] = 3;
|
|
}
|
|
// if (isset($array['voucher']) && $array['voucher']) {
|
|
// # 流水号
|
|
//// $data['szRtnMsg']
|
|
// $result['s_number'] = $array['voucher'];
|
|
// }
|
|
|
|
}
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
# 提交数据
|
|
private function submit($param, $check,$iskami=false)
|
|
{
|
|
$param = $this->param($param, $check);
|
|
if (is_string($param) || (is_array($param) && $param['status'] == 1)) {
|
|
return $param;
|
|
}
|
|
$request = $param['detail'];
|
|
unset($request['cash']);
|
|
$request['BuyCount'] = 1;
|
|
$request['AppKey'] = $this->mid;
|
|
$request['ProductCode'] = $this->getGid($param['cash']);
|
|
$request['MOrderID'] = $param['order'];
|
|
$request['CustomerIP'] = '218.0.232.223';
|
|
$request['TimesTamp'] = time();
|
|
$request['CallBackUrl'] = $this->getNotify($param['order'], 1);
|
|
if($iskami){
|
|
$map=Db::name('product_map')->where(array('cid'=>$this->product['cid'],'pid'=>$this->product['service_id'],'key'=>$this->product['key']))->find();
|
|
if(!$map)return '请配置映射';
|
|
$request['ExtendParam']=$map['json_text'];
|
|
$request['Sign'] = $this->_sign($request, array('AppKey', 'BuyCount', 'CallBackUrl', 'MOrderID', 'ProductCode', 'TimesTamp'));
|
|
}else{
|
|
$request['Sign'] = $this->_sign($request, array('AppKey', 'BuyCount', 'CallBackUrl', 'ChargeAccount', 'CustomerIP', 'MOrderID', 'MemberAmountCode', 'ProductCode', 'TimesTamp'));
|
|
}
|
|
|
|
$url = $this->host . $this->api;
|
|
|
|
$response = $this->curl('post', $url, $request);
|
|
$response = $this->response($response);
|
|
//$response['data'] = '';
|
|
//$response['msg'] = 'ok';
|
|
$channel_order_id = '';
|
|
if (isset($response['array']['OrderID'])) {
|
|
$channel_order_id = $response['array']['OrderID'];
|
|
}
|
|
|
|
$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, $param)
|
|
{
|
|
//ksort($request);
|
|
$signature_string = '';
|
|
foreach ($param as $k => $v) {
|
|
if (isset($request[$v]) && $request[$v]) {
|
|
$signature_string .= $request[$v];
|
|
}
|
|
}
|
|
|
|
//$signature_string = substr($signature_string, 0, -1);
|
|
|
|
$signature_string .= $this->token;
|
|
return strtoupper(md5($signature_string));
|
|
}
|
|
protected function decrypt($data,$publickey,$privatekey)
|
|
{
|
|
$data = openssl_private_decrypt($publickey, $data, $privatekey);
|
|
|
|
return $data;
|
|
}
|
|
} |