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

231 lines
6.1 KiB

<?php
/**
* ECSHOP 大连支付
* $Author: shenchen
* $time 2023年7月19日15:57:13
*/
if (!defined('IN_ECS'))
{
die('Hacking attempt');
}
$payment_lang = ROOT_PATH . 'languages/' .$GLOBALS['_CFG']['lang']. '/payment/dalianpay.php';
if (file_exists($payment_lang))
{
global $_LANG;
include_once($payment_lang);
}
/* 模块的基本信息 */
if (isset($set_modules) && $set_modules == TRUE)
{
$i = isset($modules) ? count($modules) : 0;
/* 代码 */
$modules[$i]['code'] = basename(__FILE__, '.php');
/* 描述对应的语言项 */
$modules[$i]['desc'] = 'dalianpay_desc';
/* 是否支持货到付款 */
$modules[$i]['is_cod'] = '0';
/* 是否支持在线支付 */
$modules[$i]['is_online'] = '1';
/* 作者 */
$modules[$i]['author'] = 'shenchen';
/* 网址 */
// $modules[$i]['website'] = 'http://www.alipay.com';
$modules[$i]['website'] = '';
/* 版本号 */
$modules[$i]['version'] = '11';
/* 配置信息 */
$modules[$i]['config'] = array(
array('name' => 'dalianpay_account', 'type' => 'text', 'value' => ''),
array('name' => 'dalianpay_key', 'type' => 'text', 'value' => ''),
array('name' => 'dalianpay_partner', 'type' => 'text', 'value' => ''),
array('name' => 'dalianpay_pay_method', 'type' => 'select', 'value' => '')
);
return;
}
/**
* 类
*/
class dalianpay
{
/**
* 构造函数
*
* @access public
* @param
*
* @return void
*/
function dalianpay()
{
}
function __construct()
{
$this->dalianpay();
}
/**
* 生成支付代码
* @param array $order 订单信息
* @param array $payment 支付方式信息
*/
function get_code($order, $payment)
{
if (!defined('EC_CHARSET'))
{
$charset = 'utf-8';
}
else
{
$charset = EC_CHARSET;
}
// $real_method = $payment['alipay_pay_method'];
$real_method = $payment['dalianpay_pay_method'];
switch ($real_method){
case '0':
$service = 'trade_create_by_buyer';
break;
case '1':
$service = 'create_partner_trade_by_buyer';
break;
case '2':
$service = 'create_direct_pay_by_user';
break;
}
$extend_param = 'isv^sh22';
$parameter = array(
'extend_param' => $extend_param,
'service' => $service,
'partner' => $payment['alipay_partner'],
//'partner' => ALIPAY_ID,
'_input_charset' => $charset,
'notify_url' => return_url(basename(__FILE__, '.php')),
'return_url' => return_url(basename(__FILE__, '.php')),
/* 业务参数 */
'subject' => $order['order_sn'],
'out_trade_no' => date("YmdHi") . $order['order_sn'] . $order['log_id'],
'price' => $order['order_amount'],
'quantity' => 1,
'payment_type' => 1,
/* 物流参数 */
'logistics_type' => 'EXPRESS',
'logistics_fee' => 0,
'logistics_payment' => 'BUYER_PAY_AFTER_RECEIVE',
/* 买卖双方信息 */
'seller_email' => $payment['alipay_account']
);
ksort($parameter);
reset($parameter);
$param = '';
$sign = '';
foreach ($parameter AS $key => $val)
{
$param .= "$key=" .urlencode($val). "&";
$sign .= "$key=$val&";
}
$param = substr($param, 0, -1);
$sign = substr($sign, 0, -1). $payment['alipay_key'];
//$sign = substr($sign, 0, -1). ALIPAY_AUTH;
// $button = '<div class="alipay" style="text-align:center"><input type="button" onclick="window.open(\'https://mapi.alipay.com/gateway.do?'.$param. '&sign='.md5($sign).'&sign_type=MD5\')" value="' .$GLOBALS['_LANG']['pay_button']. '" /></div>';
$button = '<div class="dalianpay" style="text-align:center"><input type="button" onclick="window.open(\'https://mapi.alipay.com/gateway.do?'.$param. '&sign='.md5($sign).'&sign_type=MD5\')" value="' .$GLOBALS['_LANG']['pay_button']. '" /></div>';
return $button;
}
/**
* 响应操作
*/
function respond()
{
if (!empty($_POST))
{
foreach($_POST as $key => $data)
{
$_GET[$key] = $data;
}
}
$payment = get_payment($_GET['code']);
$seller_email = rawurldecode($_GET['seller_email']);
$order_sn = str_replace($_GET['subject'], '', $_GET['out_trade_no']);
$order_sn = trim(addslashes($order_sn));
/* 检查数字签名是否正确 */
ksort($_GET);
reset($_GET);
$sign = '';
foreach ($_GET AS $key=>$val)
{
if ($key != 'sign' && $key != 'sign_type' && $key != 'code')
{
$sign .= "$key=$val&";
}
}
$sign = substr($sign, 0, -1) . $payment['alipay_key'];
//$sign = substr($sign, 0, -1) . ALIPAY_AUTH;
if (md5($sign) != $_GET['sign'])
{
return false;
}
/* 检查支付的金额是否相符 */
if (!check_money($order_sn, $_GET['total_fee']))
{
return false;
}
if ($_GET['trade_status'] == 'WAIT_SELLER_SEND_GOODS')
{
/* 改变订单状态 */
order_paid($order_sn, 2);
return true;
}
elseif ($_GET['trade_status'] == 'TRADE_FINISHED')
{
/* 改变订单状态 */
order_paid($order_sn);
return true;
}
elseif ($_GET['trade_status'] == 'TRADE_SUCCESS')
{
/* 改变订单状态 */
order_paid($order_sn, 2);
return true;
}
else
{
return false;
}
}
}
?>