php微信h5支付

近期开发用到了微信h5支付,大概分享一下代码和常见问题

注:支付调试需要在线上调试,本地调试微信回调是找不到的

1.预下单

 public function getCode($info)
    {
        $url = "https://api.mch.weixin.qq.com/pay/unifiedorder";//微信传参地址
        //1.获取调用统一下单接口所需必备参数
        $appid = $this->appid;//微信公众号appid
        $mch_id = $this->mchid;//微信支付商户号
        $key = $this->key;//自己设置的微信商家key
        $out_trade_no = $info[‘order_id‘];//平台内部订单号
        $nonce_str = MD5($out_trade_no);//随机字符串
        $body = $info[‘goods_name‘];//付款内容
        $total_fee = $info[‘amount‘] * 100;//付款金额,单位为分
        $spbill_create_ip = getIP(); //获得用户设备IP
        $attach = ‘weixinh5‘;//附加数据(自定义,在支付通知中原样返回)
        $notify_url = $this->notify_url; //微信支付成功数据回调地址,这里处理支付成功后数据库对应操作
        $trade_type = ‘MWEB‘;//交易类型,微信H5支付时固定为MWEB
        $scene_info = $this->scene_info;//场景信息
        //2.将参数按照key=value的格式,并按照参数名ASCII字典序排序生成字符串
        $signA = "appid=$appid&attach=$attach&body=$body&mch_id=$mch_id&nonce_str=$nonce_str&notify_url=$notify_url&out_trade_no=$out_trade_no&scene_info=$scene_info&spbill_create_ip=$spbill_create_ip&total_fee=$total_fee&trade_type=$trade_type";
        //3.拼接字符串
        $strSignTmp = $signA . "&key=$key";
        //4.MD5加密后转换成大写
        $sign = strtoupper(MD5($strSignTmp));
        //5.拼接成所需XML格式
        $post_data = "<xml>
                       <appid>$appid</appid>
                       <attach>$attach</attach>
                       <body>$body</body>
                       <mch_id>$mch_id</mch_id>
                       <nonce_str>$nonce_str</nonce_str>
                       <notify_url>$notify_url</notify_url>
                       <out_trade_no>$out_trade_no</out_trade_no>
                       <spbill_create_ip>$spbill_create_ip</spbill_create_ip>
                       <total_fee>$total_fee</total_fee>
                       <trade_type>$trade_type</trade_type>
                       <scene_info>$scene_info</scene_info>
                       <sign>$sign</sign>
                   </xml>";

        //6.以POST方式向微信传参,并取得微信返回的支付参数
        $dataxml = httpRequest($url, ‘POST‘, $post_data);
        $result  = (array)simplexml_load_string($dataxml, ‘SimpleXMLElement‘, LIBXML_NOCDATA); //将微信返回的XML转换成数组

//5.调用支付类中封装的支付方法并对应传参
                $result = $this->getCode($info);
                //6.当return_code和result_code均为SUCCESS,代表下单成功,将支付参数返回
                if ($result[‘return_code‘] == ‘SUCCESS‘) {
                    if ($result[‘result_code‘] == ‘SUCCESS‘) {
                        $return_url = "自定义你的支付成功返回地址?orderid=" . $order_id;//带id方便查询是否支付成功
                        $return_url = urlencode($return_url);
                        $url = $result[‘mweb_url‘] . ‘&redirect_url=‘ . $return_url;
                        $return_wx = [
                            ‘amount‘ => $info[‘amount‘],//你的支付金额
                            ‘url‘ => $url,//微信返回的拉起支付地址
                        ];
                        file_put_contents(‘url.txt‘, $url);//方便调试
            return view(‘wxpay‘, $return_wx);//到自定义付款页面
                    } elseif ($result[‘result_code‘] == ‘FAIL‘) {
                        return $this->ApiErrorNo($result[‘err_code_des‘], ‘400‘);
                    }
                } else {
                    return $this->ApiErrorNo(‘订单不存在,请核实后再提交!‘, ‘400‘);
                }
    }

2.前端付款页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>微信支付</title>
    <style type="text/css">
        body{
            font-family: "Microsoft YaHei";
        }
        .pay-box{
            position: absolute;
            top: 50%;
            margin-top: -516px;
            left: 50%;
            margin-left: -320px;
        }
        .ico{
            width: 240px;
            height: 240px;
            border-radius: 120px;
            background: #3FB837;
            color: #fff;
            display: inline-block;
            font-size: 160px;
            line-height: 240px;
        }
        .txt{
            font-size: 42px;
            padding-top: 30px;
            color: #333;
        }
        .val{
            font-size: 80px;
            font-weight: bold;
        }
        .pay{
            width: 640px;
            height: 100px;
            margin-top: 100px;
            padding: 20px;
            border-radius: 10px;
            font-size:42px;
            color: #fff;
            background: #07BF05;
            border: 0px;
            text-align: center;
        }
        a{
            color: #fff;
            background: transparent !important;
        }
    </style>
</head>
<body>
<div class="pay-box" style="text-align: center;">
    <div class="ico">
        ¥
    </div>
    <div class="txt">
        支付金额
    </div>
    <div class="val">
        ¥<span>{{$amount}}</span>
        <!-- 支付价格 -->
    </div>
    <a class="pay" href="{{$url}}"><button class="pay">确认支付</button></a>
    <!-- 这里点击调起微信支付页面 mweb_url  -->

</div>
</body>
<script>

</script>
</html>

3.支付成功微信数据回调接口操作对应数据库(例如订单支付状态改变等)

4.支付成功页面返回接口地址上面已设置,逻辑自行处理

大概这样就结束啦  有用的麻烦点个赞

原文地址:https://www.cnblogs.com/zhu-hong/p/11772652.html

时间: 2024-08-29 17:34:35

php微信h5支付的相关文章

微信h5支付demo微信H5支付demo非微信浏览器支付demo微信wap支付

一.首先先确定H5支付权限已经申请!(需要微信h5支付demo的可以加 851 488 243 备注:h5支付) 二.开发流程 1.用户在商户侧完成下单,使用微信支付进行支付 2.由商户后台向微信支付发起下单请求(调用统一下单接口)注:交易类型trade_type=MWEB 3.统一下单接口返回支付相关参数给商户后台,如支付跳转url(参数名"mweb_url"),商户通过mweb_url调起微信支付中间页 4.中间页进行H5权限的校验,安全性检查(此处常见错误请见下文) 5.如支付成

微信H5支付demo

首先我们必须得在微信公众平台和微信商业平台那边配置好相关配置 1.注册微信服务号,开通微信支付权限绑定微信商业平台(这个具体怎么操作我就不说了) 2.获取应用(公众号)appid.应用(公众号)秘钥.商户号.商户API秘钥这四个配置信息 3.微信商业平台开通H5支付权限,配置支付域名(是要ICP备案的域名), 4.微信公众号配置白名单(也就是服务器ip) 5.开始写代码实现微信H5支付了(首先我们得理清H5支付跟其他类型支付的区别) 5.1.直接用微信客户段支付的那个是JSAPI支付模式 5.2

Android通过外部浏览器调用微信H5支付,Android+PHP详解

看了好多关于讲解微信H5支付开发的文章,大多数都是通过微信内部浏览器来调用支付接口(其实就是公众号支付),可能是因为H5支付接口刚开放不久吧. 微信官方体验链接:http://wxpay.wxutil.com/mch/pay/h5.v2.php,请在微信外浏览器打开. 看了上面的体验链接,如果感兴趣,可以接着往下看,希望对你有所帮助. 一.Android端 Android端代码相对来说比较简单一些,我这边直接调用系统浏览器打开H5支付页面 Intent intent = new Intent()

微信支付—微信H5支付「非微信内部浏览器-QQ/UC浏览器等」

前言 微信支付-微信H5外部浏览器支付「本文」微信H5内部浏览器支付「待写」PC端扫码支付「待写」 一直计划着写一写微信支付相关的文章,希望能加深一下自己的印象,拖了一天又一天… 最近终于空出时间来填坑了,我将文章分为微信H5外部浏览器支付.微信H5内部浏览器支付.PC端扫码支付三篇来写. 本篇是微信H5外部浏览器支付:支付时会唤起微信APP进行支付. 扫盲补充:关于微信H5支付,分为内部浏览器支付 + 外部浏览器支付,两者还是稍微有点点区别的,内部浏览器即在微信内打开网页,进行支付,支付调用由

微信H5支付申请相关问题

之前的文章「微信支付申请相关问题」里说过微信公众号和 APP 申请微信支付,今天来说下微信 H5 支付的申请. 一.背景介绍 H5 支付是指商户在微信客户端外的移动端网页展示商品或服务,用户在前述页面确认使用微信支付时,商户发起本服务呼起微信客户端进行支付.主要用于触屏版的手机浏览器请求微信支付的场景.可以方便的从外部浏览器唤起微信支付. 微信官方体验链接:https://wxpay.wxutil.com/mch/pay/h5.v2.php,请在微信外浏览器打开. 可能很多人对 微信 H5 支付

微信H5支付 提示&quot;网络环境未能通过安全验证,请稍后再试&quot;

按照官方https://pay.weixin.qq.com/wiki/doc/api/H5.php?chapter=15_4# 接入微信的H5支付,提示"网络环境未能通过安全验证,请稍后再试",经排查发现服务器有前端机子,原先获取IP的方法有误,不能正确获取客户的IP.更改获取IP的方法,问题解决. 附获取IP的PHP函数: function ip() { if(getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CL

微信支付—微信H5支付「微信内部浏览器」

前言 微信支付-微信H5外部浏览器支付微信支付-微信H5内部浏览器支付「本文」微信支付-PC端扫码支付「待写」 本篇是微信支付系列的第二篇.微信H5内部浏览器支付,关于微信H5外部浏览器唤起微信APP支付,请参考上一篇文章. 开发环境:Java + SpringBoot + Vue +WxJava(开源SDK) 扫盲补充:关于微信内部浏览器支付,支付时会直接调起微信支付,不同于外部浏览器支付,内部浏览器支付首先需要获得当前支付用户对该公众号的唯一标识 openId「是否关注都是唯一的」,拿到 o

微信H5支付,从第三方手机浏览器中直接打开支付页面

首先在商户平台通开H5支付功能,然后帮后绑定,支付完成之后需要跳转的地址,开通之后就可以开发H5支付: 首先是签名,卧槽,说到这个就想骂人, 官方文档的解说:文科生哪能看得懂什么是集合: 下面就来签名: <?php //生成随机字符串 function getNonceNum($numLen=16){ $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; $str = "&q

微信H5支付开发全过程(除内置微信以外的浏览器)

前言:网上都是~ 呵呵 自己搞 只要花时间 多问客服总会有的 只说程序不说准备工作 自己ID 或者秘钥都准备好了  写的有点儿乱 可以把所有的方法 放在一个文件中调用 public function wechat ($doorder,$doczmoney,$doczbody) { // H5 微信支付 $wxUrl = "https://api.mch.weixin.qq.com/pay/unifiedorder"; //下单接口 $appid = ""; //公众