当前位置:   article > 正文

支付宝H5嵌入APP内部支付_app内嵌h5支付宝支付功能

app内嵌h5支付宝支付功能

前景:由于苹果支付收取手续费太高,决定采用APP内嵌套H5进行微信和支付宝进行支付。安卓手机可以直接使用APP支付功能(APP支付和H5支付,只有两个参数不同而已,以及返回的参数格式不同,仅此而已)

H5支付流程

用户添加商品生成订单,选择支付宝支付方式,点击购买按钮,前端发送ajax请求到后端,后端调用支付宝统一下单接口生成预付单。对于H5支付返回的是一个表单的字符串(APP内支付是序列号的字符串),前端接收到直接复制给页面某个div,会自动调起支付宝APP进行支付,如下图:

image.png

image.png

H5统一下单接口
    /**
     * 支付宝H5下单支付
     * @validate('OrderForm')
     * @throws \app\lib\exception\OrderException
     */
    public function aliH5Pay(Request $request)
    {
        $params = $request->param();
        //统一下单(进行调用订单模型创建订单表订单)
        $orderInfo = OrderModel::createOrder($params);
        //获取唤醒支付表单的字符串   (这里调用的是支付类,调用的则下面的方法)
        $sHtml = (new AliPay())->aliH5Pay($orderInfo);
        $result = [
            'order_info' => $orderInfo,
            'order_form' => $sHtml
        ];
        return writeJson(201, $result, '下单成功');
    }
    
     /**AliPay 类代码
     * 如果支付来源是h5,则进行生成h5代码
     * @param $params
     * @return array
     */
    public function aliH5Pay($params)
    {
        $this->signType = 'RSA2';//签名算法类型,支持RSA2和RSA,推荐使用RSA2
        $this->appId = config('alipay.app_id');
        $this->returnUrl = config('alipay.return_url');
        $this->notifyUrl = config('alipay.notify_url');
        $this->charset = 'UTF-8';
        $this->rsaPrivateKey = config('alipay.merchant_private_key');
        $this->totalFee = $params['pay_amount']; //付款金额,单位:元
        $this->orderNo = $params['order_no'];  //你自己的商品订单号,不能重复
        $this->orderName = '番鱼-' . $params['order_name'];  //订单标题
        //如果支付来源是h5,则进行生成h5代码
        $sHtml = $this->getOrderH5Str();
        return $sHtml;
    }
    
    
   /***AliPay 类代码
     *  如果支付来源是h5,则进行生成h5支付表单字符串代码
     * @return array
     */
    public function getOrderH5Str()
    {
        //请求参数
        $requestConfigs = array(
            'body' => $this->orderName,
            'out_trade_no' => $this->orderNo,
            'total_amount' => $this->totalFee, //单位 元
            'subject' => $this->orderName,  //订单标题
            'product_code' => 'QUICK_WAP_WAY', //销售产品码,商家和支付宝签约的产品码,为固定值QUICK_MSECURITY_PAY
            'timeout_express' => '2h',       //该笔订单允许的最晚付款时间,逾期将关闭交易。取值范围:1m~15d。m-分钟,h-小时,d-天,1c-当天(1c-当天的情况下,无论交易何时创建,都在0点关闭)。 该参数数值不接受小数点, 如 1.5h,可转换为 90m。
        );
        $commonConfigs = array(
            //公共参数
            'app_id' => $this->appId,
            'method' => 'alipay.trade.wap.pay',             //接口名称
            'format' => 'JSON',
            'charset' => $this->charset,
            'sign_type' => 'RSA2',
            'timestamp' => date('Y-m-d H:i:s'),
            'version' => '1.0',
            'notify_url' => $this->notifyUrl,
            'biz_content' => json_encode($requestConfigs),
        );
        $commonConfigs["sign"] = $this->generateSign($commonConfigs, $commonConfigs['sign_type']);
        $sHtml = $this->buildRequestForm($commonConfigs);
        return $sHtml;
    }
    
    public function generateSign($params)
    {
        return $this->sign($this->getSignContent($params), $this->signType);
    }
    
    /***AliPay 类代码
     * 建立请求,以表单HTML形式构造(默认)
     * @param $para_temp 请求参数数组
     * @return 提交表单HTML文本
     */
    public function buildRequestForm($para_temp)
    {
        $sHtml = "<form id='alipaysubmit' name='alipaysubmit' action='https://openapi.alipay.com/gateway.do?charset=".$this->charset."' method='POST'>";
        foreach($para_temp as $key=>$val){
            if (false === $this->checkEmpty($val)) {
                $val = str_replace("'","&apos;",$val);
                $sHtml.= "<input type='hidden' name='".$key."' value='".$val."'/>";
            }
        }
        //submit按钮控件请不要含有name属性
        $sHtml = $sHtml."<input type='submit' value='ok' style='display:none;''></form>";
        $sHtml = $sHtml."<script>document.forms['alipaysubmit'].submit();</script>";
        return $sHtml;
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97

源码都在第四个模块直接可以下载:www.lishuo.net
还有关于一个关于期刊音乐的小程序源码免费下载哦!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/700348
推荐阅读
相关标签
  

闽ICP备14008679号