app('common'); load()->app('template'); $_W['uniacid'] = $_W['weid'] = intval($_GET['body']); $setting = uni_setting($_W['uniacid'], array('payment')); if ($_GET['exterface'] == 'create_direct_pay_by_user') { $setting['payment'] = setting_load('store_pay'); $setting['payment'] = $setting['payment']['store_pay']; } if (!is_array($setting['payment'])) { exit('request failed.'); } $alipay = $setting['payment']['alipay']; if (empty($alipay)) { exit('request failed.'); } $prepares = array(); foreach ($_GET as $key => $value) { if ($key != 'sign' && $key != 'sign_type') { $prepares[] = "{$key}={$value}"; } } sort($prepares); $string = implode($prepares, '&'); $string .= $alipay['secret']; $sign = md5($string); if($sign == $_GET['sign']){ $_GET['query_type'] = 'return'; WeUtility::logging('pay-alipay', var_export($_GET, true)); if($_GET['is_success'] == 'T' && ($_GET['trade_status'] == 'TRADE_FINISHED' || $_GET['trade_status'] == 'TRADE_SUCCESS')) { if ($_GET['subject'] == '测试支付接口' && $_GET['total_fee'] == 0.01) { message('支付回调成功!', $_W['siteroot'] . 'web/index.php?c=profile&a=payment', 'success'); } $sql = 'SELECT * FROM ' . tablename('core_paylog') . ' WHERE `uniontid`=:uniontid'; $params = array(); $params[':uniontid'] = $_GET['out_trade_no']; $log = pdo_fetch($sql, $params); if (!empty($log)) { $site = WeUtility::createModuleSite($log['module']); $method = 'payResult'; if ($log['status'] == 0 && ($_GET['total_fee'] == $log['card_fee'])) { $log['transaction_id'] = $_GET['trade_no']; $record = array(); $record['status'] = '1'; pdo_update('core_paylog', $record, array('plid' => $log['plid'])); if ($log['is_usecard'] == 1 && !empty($log['encrypt_code'])) { $coupon_info = pdo_get('coupon', array('id' => $log['card_id']), array('id')); $coupon_record = pdo_get('coupon_record', array('code' => $log['encrypt_code'], 'status' => '1')); load()->model('activity'); $status = activity_coupon_use($coupon_info['id'], $coupon_record['id'], $log['module']); } if (!is_error($site)) { $site->weid = $_W['weid']; $site->uniacid = $_W['uniacid']; $site->inMobile = true; if (method_exists($site, $method)) { $ret = array(); $ret['weid'] = $log['weid']; $ret['uniacid'] = $log['uniacid']; $ret['result'] = 'success'; $ret['type'] = $log['type']; $ret['from'] = 'notify'; $ret['tid'] = $log['tid']; $ret['uniontid'] = $log['uniontid']; $ret['transaction_id'] = $log['transaction_id']; $ret['user'] = $log['openid']; $ret['fee'] = $log['fee']; $ret['is_usecard'] = $log['is_usecard']; $ret['card_type'] = $log['card_type']; $ret['card_fee'] = $log['card_fee']; $ret['card_id'] = $log['card_id']; $site->$method($ret); } } } if(!is_error($site)){ $ret['tid'] = $log['tid']; $ret['result'] = 'success'; $ret['from'] = 'return'; $site->$method($ret); exit; } } else { $order = pdo_get('site_store_order', array('orderid' => $_GET['out_trade_no'])); if (!empty($order)) { if ($order['type'] == 1) { pdo_update('site_store_order', array('type' => 3), array('orderid' => $_GET['out_trade_no'])); } cache_build_account_modules($order['uniacid']); header('Location: ./index.php?c=site&a=entry&direct=1&m=store&do=orders'); exit; } } } } else { message('支付异常,请返回微信客户端查看订单状态或是联系管理员', '', 'error'); }