123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- <?php
- /**
- * [WeEngine System] Copyright (c) 2014 WE7.CC
- * WeEngine is NOT a free software, it under the license terms, visited http://www.we7.cc/ for more details.
- */
- define('IN_MOBILE', true);
- require '../../framework/bootstrap.inc.php';
- require '../../app/common/bootstrap.app.inc.php';
- load()->app('common');
- load()->app('template');
-
- $sl = $_GPC['ps'];
- $params = @json_decode(base64_decode($sl), true);
-
- $setting = uni_setting($_W['uniacid'], array('payment'));
- if(!is_array($setting['payment'])) {
- exit('没有设定支付参数.');
- }
- $payment = $setting['payment']['unionpay'];
- require '__init.php';
-
- if (!empty($_POST) && verify($_POST) && $_POST['respMsg'] == 'success') {
- $sql = 'SELECT * FROM ' . tablename('core_paylog') . ' WHERE `uniontid`=:uniontid';
- $params = array();
- $params[':uniontid'] = $_POST['orderId'];
- $log = pdo_fetch($sql, $params);
- if(!empty($log) && $log['status'] == '0') {
- $log['tag'] = iunserializer($log['tag']);
- $log['tag']['queryId'] = $_POST['queryId'];
-
- $record = array();
- $record['status'] = 1;
- $record['tag'] = iserializer($log['tag']);
- pdo_update('core_paylog', $record, array('plid' => $log['plid']));
- if($log['is_usecard'] == 1 && $log['card_type'] == 1 && !empty($log['encrypt_code']) && $log['acid']) {
- load()->classs('coupon');
- $acc = new coupon($log['acid']);
- $codearr['encrypt_code'] = $log['encrypt_code'];
- $codearr['module'] = $log['module'];
- $codearr['card_id'] = $log['card_id'];
- $acc->PayConsumeCode($codearr);
- }
- if($log['is_usecard'] == 1 && $log['card_type'] == 2) {
- $log['card_id'] = intval($log['card_id']);
-
- pdo_update('activity_coupon_record', array(
- 'status' => 2,
- 'usetime' => TIMESTAMP,
- 'usemodule' => $log['module'],
- ), array(
- 'uniacid' => $_W['uniacid'],
- 'couponid' => $log['card_id'],
- 'uid' => $log['openid'],
- ));
- }
- }
- $site = WeUtility::createModuleSite($log['module']);
- if(!is_error($site)) {
- $method = 'payResult';
- if (method_exists($site, $method)) {
- $ret = array();
- $ret['weid'] = $log['uniacid'];
- $ret['uniacid'] = $log['uniacid'];
- $ret['result'] = 'success';
- $ret['type'] = $log['type'];
- $ret['from'] = 'return';
- $ret['tid'] = $log['tid'];
- $ret['uniontid'] = $log['uniontid'];
- $ret['user'] = $log['openid'];
- $ret['fee'] = $log['fee'];
- $ret['tag'] = $log['tag'];
- $ret['is_usecard'] = $log['is_usecard'];
- $ret['card_fee'] = $log['card_fee'];
- $ret['card_id'] = $log['card_id'];
- $site->$method($ret);
- exit('success');
- }
- }
- }
- $sql = 'SELECT * FROM ' . tablename('core_paylog') . ' WHERE `plid`=:plid';
- $paylog = pdo_fetch($sql, array(':plid' => $params['tid']));
- if(!empty($paylog) && $paylog['status'] != '0') {
- exit('这个订单已经支付成功, 不需要重复支付.');
- }
- $auth = sha1($sl . $paylog['uniacid'] . $_W['config']['setting']['authkey']);
- if($auth != $_GPC['auth']) {
- exit('参数传输错误.');
- }
- $_W['openid'] = intval($paylog['openid']);
-
- $params = array(
- 'version' => '5.0.0',
- 'encoding' => 'utf-8',
- 'certId' => getSignCertId(),
- 'txnType' => '01',
- 'txnSubType' => '01',
- 'bizType' => '000201',
- 'frontUrl' => SDK_FRONT_NOTIFY_URL . '?i='.$_W['uniacid'],
- 'backUrl' => SDK_BACK_NOTIFY_URL . '?i='.$_W['uniacid'],
- 'signMethod' => '01',
- 'channelType' => '08',
- 'accessType' => '0',
- 'merId' => SDK_MERID,
- 'orderId' => $paylog['uniontid'],
- 'txnTime' => date('YmdHis'),
- 'txnAmt' => $paylog['fee'] * 100,
- 'currencyCode' => '156',
- 'defaultPayType' => '0001',
- 'reqReserved' => $_W['uniacid'],
- );
- sign($params);
- $html_form = create_html($params, SDK_FRONT_TRANS_URL);
- echo $html_form;
|