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

475 lines
23 KiB
PHTML

5 years ago
<?php
namespace Sdk\Controller;
use Think\Controller;
use Common\Api\GameApi;
use Org\WeixinSDK\Weixin;
use Org\HeepaySDK\Heepay;
use Org\UcenterSDK\Ucservice;
class PayController extends BaseController{
private function pay($param=array()){
$table = $param['code'] == 1 ? "spend" : "deposit";
$prefix = $param['code'] == 1 ? "SP_" : "PF_";
$out_trade_no = $prefix.date('Ymd').date('His').sp_random_string(4);
$user = get_user_entity($param['user_id']);
switch ($param['apitype']) {
case 'swiftpass':
$pay = new \Think\Pay($param['apitype'],$param['config']);
break;
default:
$pay = new \Think\Pay($param['apitype'],C($param['config']));
break;
}
if (C('UC_SET') == 1&&$param['is_uc']==1) {
$uc = new Ucservice();
$uc_user=$uc->get_user_from_uid($param['user_id']);
if(empty($uc_user)){
$this->set_message(1075,"fail","UC用户数据异常");
}else{
if($param['code'] == 1){
$game = M('GameSet',"tab_");
$map['game_id'] = $param['game_id'];
$game_data = $game->where($map)->find();
$uc_id = $uc->uc_recharge($param['user_id'],$uc_user['username'],$uc_user['username'],$param['game_id'],$param['game_appid'],get_game_name($param['game_id']),0,'',$uc_user['promote_id'],$uc_user['promote_account'],"",$out_trade_no,$param['price'],time(),$param['extend'],$param['payway'],get_client_ip(),$param['sdk_version'],1,$uc_user['platform'],$game_data['pay_notify_url'],$game_data['game_key']);
}else{
$uc_id = $uc->uc_deposit($param['user_id'],$uc_user['username'],$uc_user['username'],$param['game_id'],$param['game_appid'],get_game_name($param['game_id']),0,'',$uc_user['promote_id'],$uc_user['promote_account'],"",$out_trade_no,$param['price'],time(),$param['extend'],$param['payway'],get_client_ip(),$param['sdk_version'],1,$uc_user['platform'],$game_data['pay_notify_url'],$game_data['game_key']);
}
}
}
$method=$param['sdk_version']==2?"wap":"mobile";
$discount = $this->get_discount($param['game_id'],$user['promote_id'],$param['user_id']);
$discount = $discount['discount'];
$vo = new \Think\Pay\PayVo();
$vo->setBody("充值记录描述")
->setFee($param['price'])//支付金额
->setTitle($param['title'])
->setBody($param['body'])
->setOrderNo($out_trade_no)
->setService($param['server'])
->setSignType($param['signtype'])
->setPayMethod($method)
->setTable($table)
->setPayWay($param['payway'])
->setGameId($param['game_id'])
->setGameName(get_game_name($param['game_id']))
->setGameAppid($param['game_appid'])
->setServerId(0)
->setServerName("")
->setUserId($param['user_id'])
->setAccount($user['account'])
->setUserNickName($user['nickname'])
->setPromoteId($user['promote_id'])
->setPromoteName($user['promote_account'])
->setExtend($param['extend'])
->setSdkVersion($param['sdk_version'])
->setDiscount($discount);
if($param['is_uc']==1){
return $pay->buildRequestForm($vo,1);
}else{
return $pay->buildRequestForm($vo);
}
}
public function asd(){
}
/**
*支付宝移动支付
*/
public function alipay_pay(){
#获取SDK上POST方式传过来的数据 然后base64解密 然后将json字符串转化成数组
$request = json_decode(base64_decode(file_get_contents("php://input")),true);
C(api('Config/lists'));
if (empty($request)) {
$this->set_message(1001, "fail", "登录数据不能为空");
}
if($request['price']<0){
$this->set_message(1011,"fail","充值金额有误");
}
$game_set_data = get_game_set_info($request['game_id']);
$request['apitype'] = "alipay";
$request['config'] = "alipay";
$request['signtype']= "MD5";
$request['server'] = $request['sdk_version']==2?"alipay.wap.create.direct.pay.by.user":"mobile.securitypay.pay";
$request['payway'] = 1;
if($request['sdk_version']==2){
$request['title']=$request['price'];
$request['body']=$request['price'];
//$request['price']=0.01;
$pay_url=$this->pay($request);
file_put_contents("./Application/Sdk/OrderNo/".$request['user_id']."-".$request['game_id'].".txt",base64_encode(json_encode(['pay_url'=>$this->pay($request)])));
echo base64_encode(json_encode(array('pay_url'=>"http://".$_SERVER['HTTP_HOST'].'/sdk.php/Spend/get_pay_url/user_id/'.$request['user_id'].'/game_id/'.$request['game_id'])));
}else{
$this->pay($request);
$md5_sign = $this->encrypt_md5(base64_encode($data['arg']),$game_set_data["access_key"]);
$data = array('status'=>200,"orderInfo"=>base64_encode($data['arg']),"out_trade_no"=>$data['out_trade_no'],"order_sign"=>$data['sign'],"md5_sign"=>$md5_sign);
echo base64_encode(json_encode($data));
}
}
/**
*其他支付
*/
public function outher_pay()
{
#获取SDK上POST方式传过来的数据 然后base64解密 然后将json字符串转化成数组
$request = json_decode(base64_decode(file_get_contents("php://input")), true);
C(api('Config/lists'));
if($request['price']<0){
$this->set_message(0,"fail","充值金额有误");
}
if (get_wx_type() == 0) {//官方
$table = $request['code'] == 1 ? "spend" : "deposit";
$prefix = $request['code'] == 1 ? "SP_" : "PF_";
$request['pay_order_number'] = $prefix . date('Ymd') . date('His') . sp_random_string(4);
$request['pay_way'] = 3;
$request['pay_status'] = 0;
$request['spend_ip'] = get_client_ip();
$weixn = new Weixin();
//折扣
$user = get_user_entity($request['user_id']);
$discount = $this->get_discount($request['game_id'],$user['promote_id'],$request['user_id']);
$discount = $discount['discount'];
$pay_amount = $discount * $request['price'] / 10;
$is_pay = json_decode($weixn->weixin_pay($request['title'], $request['pay_order_number'], $pay_amount, 'APP', 2), true);
if ($is_pay['status'] === 1) {
if (C('UC_SET') == 1&&$request['is_uc']==1) {
$uc = new Ucservice();
$uc_user=$uc->get_user_from_uid($request['user_id']);
if($uc_user){
if($request['code'] == 1){
$game = M('GameSet',"tab_");
$map['game_id'] = $request['game_id'];
$game_data = $game->where($map)->find();
$uc_id = $uc->uc_recharge($request['user_id'],$uc_user['username'],$uc_user['username'],$request['game_id'],$request['game_appid'],get_game_name($request['game_id']),0,'',$uc_user['promote_id'],$uc_user['promote_account'],"",$request['pay_order_number'],$request['price'],time(),$request['extend'],$request['pay_way'],get_client_ip(),$request['sdk_version'],1,$uc_user['platform'],$game_data['pay_notify_url'],$game_data['game_key']);
}else{
$uc_id = $uc->uc_deposit($request['user_id'],$uc_user['username'],$uc_user['username'],$request['game_id'],$request['game_appid'],get_game_name($request['game_id']),0,'',$uc_user['promote_id'],$uc_user['promote_account'],"",$out_trade_no,$request['price'],time(),$request['extend'],$request['pay_way'],get_client_ip(),$request['sdk_version'],1,$uc_user['platform'],$game_data['pay_notify_url'],$game_data['game_key']);
}
}
}
if(!$request['is_uc']||C('UC_SET')==0||find_uc_account($user['account'])){
if ($request['code'] == 1) {
$this->add_spend($request);
} else {
$this->add_deposit($request);
}
}
$json_data['appid'] = $is_pay['appid'];
$json_data['partnerid'] = $is_pay['mch_id'];
$json_data['prepayid'] = $is_pay['prepay_id'];
$json_data['noncestr'] = $is_pay['noncestr'];
$json_data['timestamp'] = $is_pay['time'];
$json_data['package'] = "Sign=WXPay";
$json_data['sign'] = $is_pay['sign'];
$json_data['status'] = 200;
$json_data['return_msg'] = "下单成功";
$json_data['wxtype'] = "wx";
echo base64_encode(json_encode($json_data));
}
} else {
$game_set_data = get_game_set_info($request['game_id']);
if(empty(C("weixin.partner"))||empty(C("weixin.key"))){
$this->set_message(1079, "faill", "未设置威富通账号");
}
$request['apitype'] = "swiftpass";
$request['config']=array("partner"=>trim(C("weixin.partner")),"email"=>"","key"=>trim(C("weixin.key")));
$request['signtype'] = "MD5";
$request['server'] = "unified.trade.pay";
$request['payway'] = 4;
$result_data = $this->pay($request);
$data['status'] = 200;
$data['return_code'] = "success";
$data['return_msg'] = "下单成功";
$data['token_id'] = $result_data['token_id'];
$data['out_trade_no'] = $result_data['out_trade_no'];
$data['game_pay_appid'] = $game_set_data['game_pay_appid'];
$data['wxtype'] = "wft";
echo base64_encode(json_encode($data));
}
}
//聚宝云支付
public function jubaobar_pay(){
#获取SDK上POST方式传过来的数据 然后base64解密 然后将json字符串转化成数组
$request = json_decode(base64_decode(file_get_contents("php://input")),true);
wite_text(json_encode($request),dirname(__FILE__).'/a.txt');
C(api('Config/lists'));
if($request['price']<0){
$this->set_message(1011,"fail","充值金额有误");
}
$prefix = $request['code'] == 1 ? "SP_" : "PF_";
$out_trade_no = $prefix.date('Ymd').date('His').sp_random_string(4);
$request['pay_order_number'] = $out_trade_no;
$request['pay_status'] = 0;
$request['pay_way'] = 5;
$request['spend_ip'] = get_client_ip();
if (C('UC_SET') == 1&&$request['is_uc']==1) {
$uc = new Ucservice();
$uc_user=$uc->get_user_from_uid($request['user_id']);
if($uc_user){
if($request['code'] == 1){
$game = M('GameSet',"tab_");
$map['game_id'] = $request['game_id'];
$game_data = $game->where($map)->find();
$uc_id = $uc->uc_recharge($request['user_id'],$uc_user['username'],$uc_user['username'],$request['game_id'],$request['game_appid'],get_game_name($request['game_id']),0,'',$uc_user['promote_id'],$uc_user['promote_account'],"",$request['pay_order_number'],$request['price'],time(),$request['extend'],$request['pay_way'],get_client_ip(),$request['sdk_version'],1,$uc_user['platform'],$game_data['pay_notify_url'],$game_data['game_key']);
}else{
$uc_id = $uc->uc_deposit($request['user_id'],$uc_user['username'],$uc_user['username'],$request['game_id'],$request['game_appid'],get_game_name($request['game_id']),0,'',$uc_user['promote_id'],$uc_user['promote_account'],"",$out_trade_no,$request['price'],time(),$request['extend'],$request['pay_way'],get_client_ip(),$request['sdk_version'],1,$uc_user['platform'],$game_data['pay_notify_url'],$game_data['game_key']);
}
}
}
$user = get_user_entity($request['user_id']);
if(!$request['is_uc']||C('UC_SET')==0||find_uc_account($user['account'])){
if($request['code'] == 1 ){
#TODO添加消费记录
$this->add_spend($request);
}else{
#TODO添加平台币充值记录
$this->add_deposit($request);
}
}
$data['status'] = 200;
$data['return_code'] = "success";
$data['return_msg'] = "下单成功";
$data['out_trade_no'] = $out_trade_no;
$data['appid'] = $request['sdk_version']==2?C("jubaobar.iosemail"):C("jubaobar.email");//1安卓 2苹果
echo base64_encode(json_encode($data));
}
//汇付宝支付
public function heepay_pay(){
#获取SDK上POST方式传过来的数据 然后base64解密 然后将json字符串转化成数组
$request = json_decode(base64_decode(file_get_contents("php://input")),true);
C(api('Config/lists'));
if(C('UC_SET')==1){
if(!is_array(find_uc_account($request['account']))){
$this->set_message(1080,"fail","Uc用户暂不支持");
}
}
if($request['price']<0){
$this->set_message(1011,"fail","充值金额有误");
}
$prefix = $request['code'] == 1 ? "SP_" : "PF_";
$out_trade_no = $prefix.date('Ymd').date('His').sp_random_string(4);
$request['pay_order_number'] = $out_trade_no;
$request['pay_status'] = 0;
$request['pay_way'] = 6;
$request['spend_ip'] = get_client_ip();
if($request['code'] == 1 ){
#TODO添加消费记录
$this->add_spend($request);
}else{
#TODO添加平台币充值记录
$this->add_deposit($request);
}
$pay['agent_id']="1664502";//商户号
$pay['order_no']=$out_trade_no;
$pay['time']=date('YmdHis', time());
$pay['pay_type']=$request['pay_type'];
$pay['amount']=$request['price'];
$pay['user_ip']=get_client_ip();
$pay['sign_key']="87FB9444028A4B14937A1905";//密钥
$pay['payerName']="元宝";
$pay['number']=1;
$pay['goods_note']="支付";
$heepay=new Heepay();
$token_id=$heepay->heepay_pay($pay);
$data['agent_id']="1664502";//商户号
$data['status'] = 200;
$data['return_code'] = "success";
$data['return_msg'] = "下单成功";
$data['token_id']=$token_id;
$data['out_trade_no'] = $out_trade_no;
echo base64_encode(json_encode($data));
}
/**
*平台币支付
*/
public function platform_coin_pay(){
#获取SDK上POST方式传过来的数据 然后base64解密 然后将json字符串转化成数组
$request = json_decode(base64_decode(file_get_contents("php://input")),true);
#记录信息
if($request['price']<0){
$this->set_message(1011,"fail","充值金额有误");
}
$out_trade_no = "PF_".date('Ymd').date('His').sp_random_string(4);
$request['order_number'] = $out_trade_no;
$request['pay_order_number'] = $out_trade_no;
$request['out_trade_no'] = $out_trade_no;
$request['title'] = $request['title'];
$request['pay_status'] = 1;
$request['pay_way'] = 0;
$request['spend_ip'] = get_client_ip();
if (C('UC_SET') == 1&&$request['is_uc']==1) {
$uc = new Ucservice();
$uc_user=$uc->get_user_from_uid($request['user_id']);
if(empty($uc_user)){
$this->set_message(1075,"fail","UC用户数据异常");
}else{
//UC存在则 查找其他数据库 配置文件里
$sqltype = 2;
$user_entity = M('User', 'tab_', C('DB_CONFIG2'))->where(array('account' => $request['account']))->find();
if (empty($user_entity)) {
$sqltype = 3;
$user_entity = M('User', 'tab_', C('DB_CONFIG3'))->where(array('account' => $request['account']))->find();
}
if(empty($user_entity)){
$this->set_message(1066,"fail","用户数据异常");
}
$discount = 10;
}
}else{
$user_entity = get_user_entity($request['user_id']);
$discount_arr = $this->get_discount($request['game_id'],$user_entity['promote_id'],$request['user_id']);
$discount = $discount_arr['discount'];
}
$result = false;
switch ($request['code']) {
case 1:#非绑定平台币
$user = M("user","tab_");
$real_price = $request['price'] * $discount / 10;
if ($user_entity['balance'] < $real_price) {
echo base64_encode(json_encode(array("status"=>-2,"return_code"=>"fail","return_msg"=>"余额不足")));
exit();
}
//生成UC订单
if($sqltype!=''){
$game = M('GameSet',"tab_");
$map['game_id'] = $request['game_id'];
$game_data = $game->where($map)->find();
$result = $uc->uc_recharge($request['user_id'],$uc_user['username'],$uc_user['username'],$request['game_id'],$request['game_appid'],get_game_name($request['game_id']),0,'',$uc_user['promote_id'],$uc_user['promote_account'],"",$out_trade_no,$request['price'],time(),$request['extend'],$request['pay_way'],get_client_ip(),$request['sdk_version'],1,$uc_user['platform'],$game_data['pay_notify_url'],$game_data['game_key']);
}
if($sqltype==2){
M('User','tab_',C('DB_CONFIG2'))->where(array('account'=>$user_entity['account']))->setDec("balance",$request['price']);
$uc->uc_rechange_notify($data_spned['pay_order_number'],1);
if($result){
echo base64_encode(json_encode(array("return_status"=>200,"return_code"=>"success","return_msg"=>"支付成功","out_trade_no"=>$out_trade_no)));exit;
}
}elseif($sqltype==3){
M('User','tab_',C('DB_CONFIG3'))->where(array('account'=>$user_entity['account']))->setDec("balance",$request['price']);
$uc->uc_rechange_notify($data_spned['pay_order_number'],200);
if($result){
echo base64_encode(json_encode(array("return_status"=>200,"return_code"=>"success","return_msg"=>"支付成功","out_trade_no"=>$out_trade_no)));exit;
}
}else{
#扣除平台币
$user->where("id=".$request["user_id"])->setDec("balance",$real_price);
#TODO 添加绑定平台币消费记录
$result = $this->add_spend($request);
#检查返利设置
$this->set_ratio($request['pay_order_number']);
}
break;
case 2:#绑定平台币
$user_play = M("UserPlay","tab_");
$user_play_map['user_id'] = $request['user_id'];
$user_play_map['game_id'] = $request['game_id'];
$user_play_data = $user_play->where($user_play_map)->find();
if($user_play_data['bind_balance'] < $request['price']){
echo base64_encode(json_encode(array("status"=>1076,"return_code"=>"fail","return_msg"=>"余额不足")));
exit();
}
#扣除平台币
$user_play->where($user_play_map)->setDec("bind_balance",$request['price']);
#TODO 添加绑定平台币消费记录
$result = $this->add_bind_spned($request);
break;
default:
echo base64_encode(json_encode(array("status"=>1081,"return_code"=>"fail","return_msg"=>"支付方式不明确")));
exit();
break;
}
$game = new GameApi();
$game->game_pay_notify($request,$request['code']);
if($result){
echo base64_encode(json_encode(array("return_status"=>200,"return_code"=>"success","return_msg"=>"支付成功","out_trade_no"=>$out_trade_no)));
}
else{
echo base64_encode(json_encode(array("status"=>1078,"return_code"=>"fail","return_msg"=>"支付失败")));
}
}
/**
*支付验证
*/
public function pay_validation(){
#获取SDK上POST方式传过来的数据 然后base64解密 然后将json字符串转化成数组
$request = json_decode(base64_decode(file_get_contents("php://input")),true);
$out_trade_no = $request['out_trade_no'];
$pay_where = substr($out_trade_no,0,2);
$result = 0;
$map['pay_order_number'] = $out_trade_no;
switch ($pay_where) {
case 'SP':
$data = M('spend','tab_')->field('pay_status')->where($map)->find();
$result = $data['pay_status'];
break;
case 'PF':
$data = M('deposit','tab_')->field('pay_status')->where($map)->find();
$result = $data['pay_status'];
break;
case 'AG':
$data = M('agent','tab_')->field('pay_status')->where($map)->find();
$result = $data['pay_status'];
break;
default:
exit('accident order data');
break;
}
if($result){
echo base64_encode(json_encode(array("status"=>200,"return_code"=>"success","return_msg"=>"支付成功")));
exit();
}else{
echo base64_encode(json_encode(array("status"=>1078,"return_code"=>"fail","return_msg"=>"支付失败")));
exit();
}
}
/**
*sdk客户端显示支付
*/
public function payShow(){
$map['type'] = 1;
$map['status'] = 1;
$data = M("tool","tab_")->where($map)->select();
if(empty($data)){
echo base64_encode(json_encode(array("status"=>1082,"return_code"=>"fail","return_msg"=>"暂无数据")));
exit();
}
foreach ($data as $key => $value) {
$pay_show_data[$key]['mark'] = $value['name'];
$pay_show_data[$key]['title'] = $value['title'];
}
echo base64_encode(json_encode(array("status"=>200,"return_code"=>"fail","return_msg"=>"成功","pay_show_data"=>$pay_show_data)));
exit();
}
private function wite_text($txt,$name){
$myfile = fopen($name, "w") or die("Unable to open file!");
fwrite($myfile, $txt);
fclose($myfile);
}
}