Sripe - 支付宝支付

1、后端逻辑代码: 

(1)控制器层: 

/**

* Created by PhpStorm.

* User: lph

* Date: 2018/7/5

* Time: 19:16

*/

namespace App\Http\Controllers;

use App\Business\Exceptions\BusinessException;

use App\Business\PaymentBusiness;

use App\Business\Payment\Flow\BaseFlow;

use App\Models\PrimaryOrder;

use App\Models\UserPaymentOrder;

use App\Models\UserUpgradeOrder;

use Illuminate\Http\Request;

use Illuminate\Support\Facades\Auth;

use Illuminate\Http\JsonResponse;

use Validator, Log, DB;

use App\Services\StripePay;

class StripePayController extends Controller

{

    /**

    * 信用卡支付 2018-07-06

    * @author oliver xu

    * @param Request $request

    * @return Json

*/

    public function paid(Request $request){

        // 验证参数

        $v = Validator::make($request->all(), [

            'amount'    => 'required|string',

            'currency'    => 'required|in:sgd',

            'source'    => 'required',

            'receipt_email' => 'email',

            'order_sn' => 'required|string',

        ],[

            'amount.required' => '支付金额必填',

            'amount.string' => '支付金额必须为字符串',

            'currency.required' => '货币类型必填默认sgd',

            'currency.in' => '货币只有一种sgd',

            'source.required' => '支付来源必填', //未保存客户银行卡信息的 只能调用stripe.js 获取token

            'receipt_email.email' => '接收邮件格式有误',

            'order_sn.required' => '订单ID必填',

            'order_sn.string' => '订单ID必须为字符串',

        ]);

        if($v->fails())

{

            return $this->format('1', $v->errors()->all()[0], null,'fail');

        }

      $businessName = 'OrderInfo';

      $payProvider = $request->get('payProvider');

        $orderId = PrimaryOrder::where('order_sn',$request->order_sn)->value("order_id");

        if (!$orderId){

            return $this->format('1', $request->order_sn."支付订单不存在", null,'fail');

        }

        Log::info('获取订单ID:'.$orderId);

        $business = BaseFlow::createBusinessFlow($businessName);

        $paymentOrder = new UserPaymentOrder();

        $order =null;

        $isOrder = $paymentOrder->where('order_id',$orderId)->first();

        if (!$isOrder){

            \DB::transaction(function()use($orderId,$business,$paymentOrder,$businessName,$payProvider,&$order){

                $order = $business->createOrderById($orderId,$payProvider);

                $paymentOrder->pay_provider =$payProvider;

                $paymentOrder->pay_type = 1;

                $paymentOrder->business = $businessName;

                $paymentOrder->user_id = Auth::user()->user_id;

                $paymentOrder->order_id =$order->order_id;

                $paymentOrder->price = $order->price;

                $paymentOrder->subject =$order->subject;

                $paymentOrder->desc =$order->desc;

                $paymentOrder->goods_list = json_encode($order->goods_list);

                $paymentOrder->trade_no = $order->trade_no;

                $paymentOrder->state = 1;

                $paymentOrder->save();

            });

        }elseif (in_array($isOrder->state,[2,3])){

            return $this->format('1', '已经支付', null,'success');

        }

        $paymentOrderInfo = $paymentOrder->where('order_id',$orderId)->first();

        try {

            StripePay::init();

            $param = [

                'amount' => _isLocal() ? 50 : $paymentOrderInfo->price*100,

                'currency' => $request->currency,

                'source' => $request->source,

                'metadata' => [

                    'order_sn'=> $paymentOrderInfo->trade_no,

                    'amount'=> _isLocal() ? 50 : $paymentOrderInfo->price,

                    'business'=> $paymentOrderInfo->business,

                    'ordered_at' =>$paymentOrderInfo->created_at,

                ],

                // 'customer' => $paymentOrderInfo->trade_no,

            ];

            Log::info("start step-3");

            // if ($request->has('user_id')) {

//    $param['customer'] =  $request->user_id;

// }

            if ($request->has('receipt_email')) {

                $param['receipt_email'] =  $request->receipt_email;

            }

            //支付对象

            $chargeObj = null;

            Log::info("charge对象内容前:".json_encode($param));

            $charge = \Stripe\Charge::create($param);

            Log::info("charge对象内容:".json_encode($charge));

            $charge = json_encode($charge);

            if ($charge) {

                $chargeObj = json_decode($charge);

                //支付成功

                if (isset($chargeObj->status) || $chargeObj->status == 'succeeded') {

                    $flowBusiness = BaseFlow::createBusinessFlow($paymentOrderInfo->business);

                    $result = $flowBusiness->buyGoods($paymentOrderInfo);

                    UserPaymentOrder::query()->where('id',$paymentOrderInfo->id)->where('state',1)->update(['state'=>3, 'succeeded_at' => date('Y-m-d H:i:s')]);

                    Log::info('购买结果'.json_encode($result));

                    return $this->format('0', '支付成功', null,'success');

                }else{

                    //支付失败

                    throw new BusinessException("未支付成功");

                }

}

        }catch(\Exception $e){

            \Log::info($e->getMessage());

            return $this->format('1', '支付失败;', null,'fail');

        }

}

    /**

    * 信用卡支付 礼包购买

    * @param Request $request

    * @return Json

*/

    public function paidGift(Request $request){

        // 验证参数

        $v = Validator::make($request->all(), [

            'amount'    => 'required|string',

            'currency'    => 'required|in:sgd',

            'source'    => 'required',

//            'receipt_email' => 'email',

//            'order_sn' => 'required|string',

            'parentNo' => 'required',

        ],[

            'amount.required' => '支付金额必填',

            'amount.string' => '支付金额必须为字符串',

            'currency.required' => '货币类型必填默认sgd',

            'currency.in' => '货币只有一种sgd',

            'source.required' => '支付来源必填', //未保存客户银行卡信息的 只能调用stripe.js 获取token

//            'receipt_email.email' => '接收邮件格式有误',

//            'order_sn.required' => '订单ID必填',

//            'order_sn.string' => '订单ID必须为字符串',

            'parentNo.required' => '推荐人号必传',

        ]);

        if($v->fails())

{

            return $this->format('1', $v->errors()->all()[0], null,'fail');

        }

        $paymentOrder = new UserPaymentOrder();

        $business = new PaymentBusiness();

        $data = $business->createxykOrder();

        $orderId = $data['order_id'];

//

//        $businessName = 'OrderInfo';

//        $payProvider = $request->get('payProvider');

//

//        $orderId = UserUpgradeOrder::where('order_sn',$request->order_sn)->value("id");

//        if (!$orderId){

//            return $this->format('1', $request->order_sn."支付订单不存在", null,'fail');

//        }

        $business = $request->get('business', 'UserUpgradeOrder');

        $paymentOrderInfo = $paymentOrder->where('order_id',$orderId)->where('business', $business)->first();

        if(!$paymentOrderInfo){

            return $this->format('1', "支付订单不存在", null,'fail');

        }elseif (in_array($paymentOrderInfo->state,[2,3])){

            return $this->format('1', '已经支付', null,'success');

        }

        try {

            //\Stripe\Stripe::setApiKey(StripePay::_getKey());

            StripePay::init();

            $param = [

                'amount' =>_isLocal() ? 50 : $paymentOrderInfo->price*100,

                'currency' => $request->currency,

                'source' => $request->source,

                'metadata' => [

                    'order_sn'=> $paymentOrderInfo->trade_no,

                    'amount'=> _isLocal() ? 50 : $paymentOrderInfo->price,

                    'business'=> $paymentOrderInfo->business,

                    'ordered_at' =>$paymentOrderInfo->created_at,

                ],

                // 'customer' => $paymentOrderInfo->trade_no,

            ];

            Log::info("start step-3");

            // if ($request->has('user_id')) {

//    $param['customer'] =  $request->user_id;

// }

            if ($request->has('receipt_email')) {

                $param['receipt_email'] =  $request->receipt_email;

            }

            //支付对象

            $chargeObj = null;

            Log::info("礼包 charge对象内容前:".json_encode($param));

            $charge = \Stripe\Charge::create($param);

            Log::info("礼包 charge对象内容:".json_encode($charge));

            $charge = json_encode($charge);

            if ($charge) {

                $chargeObj = json_decode($charge);

                //支付成功

                if (isset($chargeObj->status) || $chargeObj->status == 'succeeded') {

                    $flowBusiness = BaseFlow::createBusinessFlow($paymentOrderInfo->business);

                    $result = $flowBusiness->buyGoods($paymentOrderInfo);

                    UserPaymentOrder::query()->where('id',$paymentOrderInfo->id)->where('state',1)->update(['state'=>3, 'succeeded_at' => date('Y-m-d H:i:s')]);

                    Log::info('购买结果'.json_encode($result));

                    return $this->format('0', '支付成功', null,'success');

                }else{

                    //支付失败

                    throw new BusinessException("未支付成功","388",null);

                }

}

        }catch(\Exception $e){

            \Log::info(__METHOD__ . $e->getMessage());

            return $this->format('1', '支付失败;', null,'fail');

        }

}

    /**

    * Notes:  创建 H5 订单

    * User: lphwxl

    * @param Request $request

    * @return JsonResponse

    * @throws BusinessException

*/

    public function createWebOrd(Request $request){

        $business = new PaymentBusiness();

        return JsonResponse::create([

            'result'=>'success',

            'error'=>'0',

            'msg'=>'创建订单成功!',

            'data'=>$business->createxykOrder()

        ]);

    }

    /**

    * 创建支付订单

    * @return static

*/

    public function orderToAlipay(){

        $business = new PaymentBusiness();

        return JsonResponse::create([

            'result'=>'success',

            'error'=>'0',

            'msg'=>'提交成功',

            'data'=>$business->createxykOrder()

        ]);

    }

    public function stripeSourceChargeable(Request $request){

        //发起stripe确认支付

        $data = $request->input();

        try{

            $charge = StripePay::sendCharge($data['data']['object']['id'],$data['data']['object']['client_secret']);

            if(!$charge){

                throw new BusinessException('发起确认扣款失败!,源Source:'.$data['data']['object']['id']);

            }

            //修改订单状态

            self::_changeOrderStatus(StripePay::$_userPayOrder);

        }catch(\Exception $e){

            throw new BusinessException('stripe_alipay回调异常!源Source:'.$data['data']['object']['id']);

        }

}

    /**

    * stripe webhooks 异步通知

    */

    public function stripeNotify(Request $request){

        StripePay::checkoutWebhookSignatures();

        $data = $request->input();

        try{

            $usrpayObj = UserPaymentOrder::where('state','=',1)

                                        ->where('trade_no',$data['data']['object']['metadata']['order_sn'])

                                        ->where('business',$data['data']['object']['metadata']['business'])

                                        ->first();

            if(!$usrpayObj)

                return http_response_code(200);

            //修改订单状态

            self::_changeOrderStatus($usrpayObj);

        }catch(\Exception $e){

            \Log::info($e->getMessage());

            throw new BusinessException('stripe_alipay回调异常!源Source:'.$data['data']['object']['id']);

        }

}

    public function stripeSourceSucceeded(Request $request){

        //后期处理,邮件通知

        //Log::info('stripeSourceSucceeded:'.json_encode($request->all()));

    }

    static private function _changeOrderStatus(UserPaymentOrder $orderObj){

        try{

            DB::beginTransaction();

            $res = UserPaymentOrder::query()->where('id',$orderObj->id)

                                    ->where('state','=',1)

                                    ->update([

                                        'state'=>3,

                                        'succeeded_at'=>date('Y-m-d H:i:s')

                                    ]);

            $flowBusiness = BaseFlow::createBusinessFlow($orderObj->business);

            $result = $flowBusiness->buyGoods($orderObj);

            if($res && $result) {

                DB::commit();

            }

            else

                DB::rollBack();

            Log::info('购买结果'.json_encode($result));

        }catch (\Exception $e){

            DB::rollBack();

            throw new BusinessException('strip回调异常!'.$e->getMessage());

        }

}

}


(2)支付服务层:

namespace App\Services;

use App\Business\Exceptions\BusinessException;

use App\Business\Exceptions\OrderNotExistsException;

use App\Business\PaymentBusiness;

use App\Models\UserPaymentOrder;

class StripePay{

    static private $_source = null;

    static public $_userPayOrder = null;

    /**

    * Notes: 判断 Source源 的状态

    * User: lphwxl

    * @param string $sourceID

    * @return \Stripe\StripeObject

*/

    static public function _sourceIsExists(string $sourceID,string $client_secret){

        self::init();

        $source = \Stripe\Source::retrieve($sourceID,[

            'api_key'=>'sk_live_xxxxxxxxxxxxxu',//self::_getKey()

            'client_secret'=>$client_secret

        ]);

        if($source && ($source instanceof  \Stripe\StripeObject) && ($source->id == $sourceID)){

            self::$_source = $source;

        }else

            throw new BusinessException('扣款失败,源source:'.$sourceID);

    }

    /**

    * Notes: 发起 确认扣款

    * User: lphwxl

    * @param string $sourceID

    * @param array $params

    * @return null|\Stripe\ApiResource

    * @throws BusinessException

    * @throws OrderNotExistsException

*/

    static public function sendCharge(string $sourceID,string $client_secret,array $params=[]){

        self::_sourceIsExists($sourceID,$client_secret);

        if(self::$_source && self::$_source->status == 'chargeable'){

            self::_UserPayOrderIsExists(self::$_source->metadata['order_sn'],self::$_source->metadata['order_id']);

            $param = [

                'amount' => _isLocal() ? 50:self::$_userPayOrder->price*100,

                'currency' => self::$_source->currency,

                'source' => self::$_source->id,

                'metadata' => [

                    'order_sn'=> self::$_userPayOrder->trade_no,

                    'order_id'=> self::$_userPayOrder->order_id,

                    'amount'=> _isLocal() ? 50: self::$_userPayOrder->price*100,

                    'business'=> self::$_userPayOrder->business,

                    'ordered_at' =>self::$_userPayOrder->created_at,

                ],

            ];

            try{

                $charge = \Stripe\Charge::create($param);

                if(!($charge instanceof \Stripe\ApiResource)){

                    throw new BusinessException('确认扣款失败,源Source:'.$sourceID);

                }

                if($charge && $charge->status == 'succeeded'){

                    return $charge;

                }

                return null;

            }catch (\Exception $e){

                throw new BusinessException('确认扣款失败,源Source:'.$sourceID);

            }

        }else

            throw new BusinessException('确认扣款失败,源Source:'.$sourceID);

    }

    static public function checkoutWebhookSignatures($type='ChargeSucceed'){

        self::init();

        $type = 'get'.$type.'Secret';

        $endpoint_secret = self::$type();

        $payload = @file_get_contents('php://input');

        $sig_header = $_SERVER['HTTP_STRIPE_SIGNATURE'];

        $event = null;

        try {

            $event = \Stripe\Webhook::constructEvent(

                $payload, $sig_header, $endpoint_secret

            );

        } catch(\UnexpectedValueException $e) {

            http_response_code(400);

            exit();

        } catch(\Stripe\Error\SignatureVerification $e) {

            // Invalid signature

            http_response_code(400);

            exit();

        }

        // Do something with $event

//http_response_code(200); // PHP 5.4 or greater

    }

    /**

    * Notes: 获取 api-key

* User: lphwxl

    * @return mixed

*/

    static public function _getKey(){

        if(_isLocal())

            return config('stripe.STRIPE_API_TEST_KEY');

        return config('stripe.STRIPE_API_KEY');

    }

    /**

    * Notes: 获取 webhook 的密钥

    * User: lphwxl

    * @return mixed

*/

    static public function getChargeSucceedSecret(){

        if(_isLocal())

            return config('stripe.TEST_CHARGE_SUCCEEDED_SECRET');

        return config('stripe.CHARGE_SUCCEEDED_SECRET');

    }

    static public function init(){

        \Stripe\Stripe::setApiKey('sk_live_rBxxxxxxxxTxxxxxxxxxx');

        //\Stripe\Stripe::setApiKey(self::_getKey());

    }

    /**

    * Notes: 判断支付订单是否存在

    * User: lphwxl

    * @param string $order_sn

    * @param int $order_id

    * @throws BusinessException

    * @throws OrderNotExistsException

*/

    static public function _UserPayOrderIsExists(string $order_sn,int $order_id){

        $paymentOrder = new UserPaymentOrder();

        $paymentOrderInfo = $paymentOrder->where('order_id',$order_id)

                                        ->where('trade_no',$order_sn)

                                        ->first();

        if(!$paymentOrderInfo){

            throw new OrderNotExistsException('stripe_alipay订单不存在!');

        }elseif (in_array($paymentOrderInfo->state,[2,3])){

            throw new BusinessException('stripe_alipay订单已支付!');

        }

        self::$_userPayOrder = $paymentOrderInfo;

    }

}

?>

(3)配置信息:

<?php

return [

    'STRIPE_API_TEST_KEY'=>'sk_test_fXXXXXXXXXXXXX',

    'STRIPE_API_KEY'=>'sk_live_XXXXXXXXmu',

    'TEST_CHARGE_SUCCEEDED_SECRET'=>'whsec_XXXXXXXXXXXXXX',

    'CHARGE_SUCCEEDED_SECRET'=>'whsec_XXXXXXXXXXXXXXXXXX',

];

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容