PHP PC端微信掃碼支付【模式二】詳細教程-附帶源碼

PC端微信掃碼支付

博主寫這破玩意兒的時候花了大概快兩天時間才總體的弄懂邏輯,考慮了一下~仍是把全部代碼都放出來給你們~抱着開源大無私的精神!誰叫我擅長拍黃片呢?同時也感謝我剛入行時候那些無私幫過個人程序員們!javascript

  • 首先仍是先給你們上效果圖吧(樣式我也會一併給你們的,漂亮吧?騷年們!)!php

clipboard.png


  • 各位騷年們~請不要着急往下看代碼,先給你們解釋怎麼獲取到的二維碼html

上面的這圖,用到了Jquery,Layer這兩個js,你們請本身下載一下(連接本身點文字就行)。java

整個流程簡紹:點擊支付後調用layer彈出窗口->ajax獲取支付的二維碼->輪詢支付狀態!jquery

補充!不要小心輪詢佔用服務器資源的問題~由於假如同時有上萬人等着支付的話,我相信你公司不會缺服務器這點小錢了!因此放心用吧!另外~按照個人邏輯來講應該是很是安全。請你們耐心看下去,雖然代碼拿去就能用!但仍是但願授之以漁!程序員

ok!下面正式開始了喲!~你們注意仔細閱讀代碼。ajax


第一步 首先把官方的微信demo下載下來進行配置部署正則表達式

給你們個傳送門-> PHP微信支付demo下載數據庫

拿到文件後解壓,解壓後把文件夾更名爲payment(也能夠隨意改,可是博主以爲這樣規範點!)然後上傳至項目的根目錄,各位大佬不知道什麼是根目錄就請看這(/).其實我是逗大家的。
 
 
 然後進入微信的商戶後臺,設置api的key注意看下圖(網上隨意找的~醜了點,將就吧!)設置完後,下載證書文件。然後把證書解壓出來!放到微信支付demo裏面,也就是上一步上傳服務器的demo文件夾中!下面是詳細步驟:
  1. 設置密鑰(如圖)
    clipboard.pngjson

  2. 下載證書,獲得壓縮文件夾,解壓後上傳到payment中的cert中!(如圖,圖上有路徑)
    clipboard.png

  3. 在此順便給logs文件夾(支付日誌)一個寫入的權限
    clipboard.png

  4. 修改微信支付demo中的配置文件WxPay.Config.php(如圖:路徑)
    clipboard.png

//只用修改第2五、2六、2七、28行(示例)
const APPID = 'wx2a3f1e5246886123';    //微信公衆號的APPID
const MCHID = '1300778123';     //微信商戶號   
const KEY = '619fd0f3f9c64550964bbe5b94dba123';     //微信商戶密鑰(上面步驟中設置的那個)
const APPSECRET = '5c8289b72600936f813ec1939e68f123';     //微信公衆號的APPSECRET

第一步分的配置咋們就完成了,請各位大佬繼續跟着小的往下走!

第二部 調整前段代碼 大部分都是JS,不懂JS得直接略過吧,不然看着難受!

對於點擊後彈出支付的這一塊邏輯,擼主的思路是:點擊支付按鈕->執行Ajax獲取到二維碼展現在頁面->開始執行輪詢獲取支付狀態;(擼主雖然JS很菜,可是每一條代碼後面都會註釋給你們,比我菜的能夠看一下)
  • 建立獲取二維碼的文件 getPayQrcode.php

<?php
    // 放入老衲前不久寫的curl函數 用curl方法獲取二維碼
    function curlGet($url) {  
        $ch = curl_init();  
        curl_setopt($ch, CURLOPT_URL, $url);  
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);   
        curl_setopt($ch, CURLOPT_HEADER, false);  
        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);          
        return curl_exec($ch);  
    }
    // 正式流程開始 返回的二維碼是帶信息的,因此須要先接收商品信息
    // 好比:我是get過來商品的id,然後再進行查詢數據庫;這裏你們隨意;
    $goodsId = $_GET['goodsId'];
    // 利用商品ID查詢到商品名稱和價格
    $goodsName = '好日子牌姨媽巾';
    $goodsPrice = '250';
    // 下面構造請求二維碼的連接(因爲是獲取二維碼支付,因此咋們請求的是native.php;後面會對該文件進行詳細講解)
    $url = 'http://www.baidu.com/payment/example/native.php?goodsName='.$goodsName.'&goodsPrice='.goodsPrice;
    // 執行curlGet()函數
    $data = curlGet($url);
    // preg_match_all函數進行全局正則表達式匹配,獲取到二維碼的連接。 
    preg_match('/<\s*img\s+[^>]*?src\s*=\s*(\'|\")(.*?)\\1[^>]*?\/?\s*>/i',$data,$matches);
    preg_match('/\|\|(.*)\|\|/',$matches[0],$aac);
    // 構造返回信息
    $obj['status'] = 'success';
    $obj['code'] = $aac[1];    // 此值爲返回交易碼【用來確認訂單支付狀態的】
    $obj['price'] = $goodsPrice;
    $obj['msg'] = '/payment/example/'.$matches['2']; // 請求返回的二維碼
    return json_encode($obj);// 返回json
    // 獲取二維碼的文件已經ok!繼續下一步
  • 設置微信支付demo中的掃碼支付文件 payment/example/native.php

//在大概19行找到該代碼 $notify = new NativePay(); 並在下方添加獲取商品名字和商品價格的代碼
// 接收get過來的商品價格和名稱
$goodsPrice = $_GET['goodsPrice'];
$goodsName = $_GET['goodsName'];
//下面修改從第32號開始的一大堆$input開頭的
$input = new WxPayUnifiedOrder();
$input->SetBody($goodsName);//商品名稱
$input->SetAttach("大姨媽商城");//本身設置
$num = WxPayConfig::MCHID.date("YmdHis");//訂單號
$input->SetOut_trade_no($num);
$input->SetTotal_fee($goodsPrice*100);//注意!!!!!!!!!因爲是以分爲單位結算,因此必定要記得商品價格*100;別到時候下崗了來怪擼主
$input->SetTime_start(date("YmdHis"));
$input->SetTime_expire(date("YmdHis", time() + 600));
$input->SetGoods_tag($goodsName);//下面的這些參數你們本身看一下文檔吧!意義都不大,擼主腎虛,要早點寫完早點睡!
$input->SetNotify_url("/payment/example/notify.php");
$input->SetTrade_type("NATIVE");
$input->SetProduct_id("123456789");
$result = $notify->GetPayUrl($input);
//print_r($result);//最終的信息,你們能夠打印了進行調試
$url2 = $result["code_url"];
// ok!整個文件的PHP代碼就完畢了!在這如下的html代碼所有把它幹掉,把擼主準備的這段貼上去 這段代碼不作什麼解釋了,也是用於查詢訂單狀態的輪詢,調試用的~!下面還會用到一次,講的很詳細
<html>
<head>
    <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
    <meta name="viewport" content="width=device-width, initial-scale=1" /> 
    <title>微信支付樣例</title>
</head>
<body>
    <div style="margin-left: 10px;color:#556B2F;font-size:30px;font-weight: bolder;">掃描支付模式二</div><br/>
    <img alt="||<?php echo $num?>||" src="qrcode.php?data=<?php echo urlencode($url2);?>" style="width:150px;height:150px;"/>
    <div id="myDiv"></div><div id="timer">0</div>
</body>
<script>  
    //設置每隔1000毫秒執行一次load() 方法  
    var myIntval=setInterval(function(){load()},1000);  
    function load(){  
       document.getElementById("timer").innerHTML=parseInt(document.getElementById("timer").innerHTML)+1; 
        var xmlhttp;    
        if (window.XMLHttpRequest){    
            // code for IE7+, Firefox, Chrome, Opera, Safari    
            xmlhttp=new XMLHttpRequest();    
        }else{    
            // code for IE6, IE5    
            xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");    
        }    
        xmlhttp.onreadystatechange=function(){    
            if (xmlhttp.readyState==4 && xmlhttp.status==200){    
                trade_state=xmlhttp.responseText;  
                if(trade_state=='SUCCESS'){  
                    document.getElementById("myDiv").innerHTML='支付成功';  
                    //alert(transaction_id);  
                    //延遲3000毫秒執行tz() 方法
                    clearInterval(myIntval);  
                    setTimeout("location.href='success.php'",3000);  

                }else if(trade_state=='REFUND'){  
                    document.getElementById("myDiv").innerHTML='轉入退款'; 
                    clearInterval(myIntval); 
                }else if(trade_state=='NOTPAY'){  
                    document.getElementById("myDiv").innerHTML='請掃碼支付';  
                      
                }else if(trade_state=='CLOSED'){  
                    document.getElementById("myDiv").innerHTML='已關閉';  
                    clearInterval(myIntval);
                }else if(trade_state=='REVOKED'){  
                    document.getElementById("myDiv").innerHTML='已撤銷';  
                    clearInterval(myIntval);
                }else if(trade_state=='USERPAYING'){  
                    document.getElementById("myDiv").innerHTML='用戶支付中';  
                }else if(trade_state=='PAYERROR'){  
                    document.getElementById("myDiv").innerHTML='支付失敗'; 
                    clearInterval(myIntval); 
                }  
                 
            }    
        }    
        //orderquery.php 文件返回訂單狀態,經過訂單狀態肯定支付狀態  
        xmlhttp.open("POST","orderquery.php",false);    
        //下面這句話必須有    
        //把標籤/值對添加到要發送的頭文件。    
        xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");    
        xmlhttp.send("out_trade_no=<?php echo $num;?>");  
         
        }  
    </script>
  • 微信支付demo訂單查詢文件 payment/example/orderquery.php

header("Access-Control-Allow-Origin:*"); // 由於擼主的支付實在另一臺服務器上,因此給了一個域頭
ini_set('date.timezone','Asia/Shanghai');// 設置一下時區
error_reporting(E_ERROR); // 關閉報錯
require_once "../lib/WxPay.Api.php";
require_once 'log.php';
 
//初始化日誌
$logHandler= new CLogFileHandler("./logs/".date('Y-m-d').'.log');
$log = Log::Init($logHandler, 15);
 
function printf_info($data)
{
    foreach($data as $key=>$value){
        echo "<font color='#f00;'>$key</font> : $value <br/>";
    }
}
 
// 一下兩個if的判斷均爲判斷訂單的狀態,這裏擼主建議去微信官網進行查閱,下面有傳送門送你過去
if(isset($_REQUEST["transaction_id"]) && $_REQUEST["transaction_id"] != ""){
    $transaction_id = $_REQUEST["transaction_id"];
    $input = new WxPayOrderQuery();
    $input->SetTransaction_id($transaction_id);
    //printf_info(WxPayApi::orderQuery($input));
    $result=WxPayApi::orderQuery($input);
    echo $result['trade_state'];
    exit();
}
 
if(isset($_REQUEST["out_trade_no"]) && $_REQUEST["out_trade_no"] != ""){
    $out_trade_no = $_REQUEST["out_trade_no"];
    $input = new WxPayOrderQuery();
    $input->SetOut_trade_no($out_trade_no);
    //printf_info(WxPayApi::orderQuery($input));
    $result=WxPayApi::orderQuery($input);
    $status['code'] =  $result['trade_state'];
    $status['openid'] =  $result['openid'];
    $status['total_fee'] =  $result['total_fee'];
    $status['transaction_id'] =  $result['transaction_id'];
    $status['time'] =  $result['time_end'];
    //print_r($result);
    print_r(json_encode($status));
    exit();
}

傳送門 微信返回錯誤代碼解釋

  • 點擊支付按鈕的代碼

// 前段代碼 樣式用你們本身的就行,不用照抄
<div class="goods_btn">
    <div class="buy" onclick="GetPay()">當即購買</div>
</div>

// JS代碼 js代碼中嵌入的樣式,無需修改!和效果圖同樣的!
//接入微信掃碼支付
function GetPay() {
    // 用ajax獲取到支付的二維碼
    var payQrcode = '';
    var payPrice = '';
    var payOrderCode = '';
    // 執行Ajax請求
    $.get('/getPayQrcode.php',{"goodsId":"商品的ID"},function(ret){
        var obj = JSON.parse(ret) // 把字符串進行轉換
        // 判斷返回數據是否正常(因爲請求通常不會出問題,因此在獲取二維碼的getPayQrcode.php文件沒有寫返回fail)
        if (obj.status == 'success') {
            payQrcode = 'http://www.baidu.com'+obj.msg;//二維碼連接
            payPrice = obj.price; //商品價格
            payOrderCode = obj.code; //交易碼
            //執行layer彈層
            layer.open({
                type: 1,
                skin: 'layui-layer-demo', //樣式類名,隨意!
                closeBtn: 0, //不顯示關閉按鈕
                title:false, //關閉title部分
                anim: 2,
                area: ['300px', '450px'], //層的寬高
                shadeClose: true, //開啓遮罩關閉
                content: '<div style="color: #666;margin: 5px 0 0 10px;position: absolute;right:.5rem;" onclick="layer.closeAll()">X</div>'+'<div style="text-align: center;"><img style="width: 4rem;padding:2rem 0 1rem 0;" src="{{ asset('./images/wx.png') }}" alt="" /><br><b style="font-weight: 100;color: #888;">請打開微信 掃碼進行支付 </b><div class="blank"></div>支付金額:<span style="color: red;">'+payPrice+'</span> 元</div><div class="blank"></div>'+'<div style="text-align: center"><img src="'+payQrcode+'" class="resize" style="width:70%;"></div><div id="myDiv" style="width: 100%;height: 1.5rem;bottom: 2rem;position:absolute;text-align:center;font-size: 1.2rem;color: #04BE02;"></div><div id="timer" style="display:none;">0</div>'
            });
            
            // 輪詢代碼開始
            // 設置每隔1000毫秒執行一次load() 方法  
            var myIntval=setInterval(function(){load()},1000);  
            function load(){  
                var xmlhttp;  
               // 輪詢的瀏覽器設置  
                if (window.XMLHttpRequest){    
                    // code for IE7+, Firefox, Chrome, Opera, Safari    
                    xmlhttp=new XMLHttpRequest();    
                }else{    
                    // code for IE6, IE5    
                    xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");    
                }    
                xmlhttp.onreadystatechange=function(){    
                    if (xmlhttp.readyState==4 && xmlhttp.status==200){    
                        trade_state=JSON.parse(xmlhttp.responseText); 
                        console.log(trade_state);//打印查看輪詢的狀態,也能夠關閉。
                        //判斷訂單支付狀態 並用document.getElementById方法賦值到myDiv中;
                        if(trade_state.code=='SUCCESS'){  
                            document.getElementById("myDiv").innerHTML='支付成功'; 
                            //延遲3000毫秒執行tz() 方法
                            clearInterval(myIntval);
                            //進行跳轉。
                            setTimeout("location.href='./",1500);  
                        }else if(trade_state.code=='REFUND'){  
                            document.getElementById("myDiv").innerHTML='轉入退款'; 
                            clearInterval(myIntval); 
                        }else if(trade_state.code=='NOTPAY'){  
                            document.getElementById("myDiv").innerHTML='請掃碼支付';        
                        }else if(trade_state.code=='CLOSED'){  
                            document.getElementById("myDiv").innerHTML='已關閉';  
                            clearInterval(myIntval);
                        }else if(trade_state.code=='REVOKED'){  
                            document.getElementById("myDiv").innerHTML='已撤銷';  
                            clearInterval(myIntval);
                        }else if(trade_state.code=='USERPAYING'){  
                            document.getElementById("myDiv").innerHTML='用戶支付中';  
                        }else if(trade_state.code=='PAYERROR'){  
                            document.getElementById("myDiv").innerHTML='支付失敗'; 
                            clearInterval(myIntval); 
                        }  
                         
                    }    
                }    
                //orderquery.php 文件返回訂單狀態,經過訂單狀態肯定支付狀態  
                xmlhttp.open("POST","http://www.baidu.com/payment/example/orderquery.php",false);    
                //下面這句話必須有    
                //把標籤/值對添加到要發送的頭文件。    
                xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");    
                xmlhttp.send("out_trade_no="+payOrderCode+"");           
                } 
        }else{
            layer.msg('請求失敗!', {icon: 5}); 
        }
    });
}
// 上面的這段js代碼稍微有點複雜,願你們耐心看!擼主是js菜雞、文盲、白癡;大佬們勿噴!
ok!到此爲止,整個流程就已經結束了!~上面的代碼僅供參考!~下面擼主會貼出整套代碼來造福社會!

原裝進口代碼,麻煩你們記得點贊、關注、收藏,謝謝!

此套代碼是原生的php!你們隨意用!

  • 調取支付頁面代碼

<div class="goods_btn">
    <div class="buy" onclick="GetPay()">當即購買</div>
</div>
<script type="text/javascript">
//接入微信掃碼支付
function GetPay() {
    //用ajax獲取到支付的二維碼
    var payQrcode = '';
    var payPrice = '';
    var payOrderCode = '';
    $.get('/getPayQrcode.php',{"goodsId":"<?php echo $goodsInfo->id;?>"},function(ret){
        var obj = JSON.parse(ret)
        if (obj.status == 'success') {
            payQrcode = 'http://www.baidu.com'+obj.msg; 
            payPrice = obj.price;
            payOrderCode = obj.code;
            layer.open({
                type: 1,
                skin: 'layui-layer-demo', //樣式類名
                closeBtn: 0, //不顯示關閉按鈕
                title:false,
                anim: 2,
                area: ['300px', '450px'],
                shadeClose: true, //開啓遮罩關閉
                content: '<div style="color: #666;margin: 5px 0 0 10px;position: absolute;right:.5rem;" onclick="layer.closeAll()">X</div>'+'<div style="text-align: center;"><img style="width: 4rem;padding:2rem 0 1rem 0;" src="./images/wx.png" alt="" /><br><b style="font-weight: 100;color: #888;">請打開微信 掃碼進行支付 </b><div class="blank"></div>支付金額:<span style="color: red;">'+payPrice+'</span> 元</div><div class="blank"></div>'+'<div style="text-align: center"><img src="'+payQrcode+'" class="resize" style="width:70%;"></div><div id="myDiv" style="width: 100%;height: 1.5rem;bottom: 2rem;position:absolute;text-align:center;font-size: 1.2rem;color: #04BE02;"></div><div id="timer" style="display:none;">0</div>'
            });

            // 設置每隔1000毫秒執行一次load() 方法  
            var myIntval=setInterval(function(){load()},1000);  
            function load(){  
               //document.getElementById("timer").innerHTML=parseInt(document.getElementById("timer").innerHTML)+1; 
                var xmlhttp;    
                if (window.XMLHttpRequest){    
                    // code for IE7+, Firefox, Chrome, Opera, Safari    
                    xmlhttp=new XMLHttpRequest();    
                }else{    
                    // code for IE6, IE5    
                    xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");    
                }    
                xmlhttp.onreadystatechange=function(){    
                    if (xmlhttp.readyState==4 && xmlhttp.status==200){    
                        trade_state=JSON.parse(xmlhttp.responseText); 
                        console.log(trade_state);
                        
                        if(trade_state.code=='SUCCESS'){  
                            document.getElementById("myDiv").innerHTML='支付成功';  
                            //alert(transaction_id);  
                            //延遲3000毫秒執行tz() 方法
                            clearInterval(myIntval);  
                            setTimeout("location.href='./",1500);  

                        }else if(trade_state.code=='REFUND'){  
                            document.getElementById("myDiv").innerHTML='轉入退款'; 
                            clearInterval(myIntval); 
                        }else if(trade_state.code=='NOTPAY'){  
                            document.getElementById("myDiv").innerHTML='請掃碼支付';  
                              
                        }else if(trade_state.code=='CLOSED'){  
                            document.getElementById("myDiv").innerHTML='已關閉';  
                            clearInterval(myIntval);
                        }else if(trade_state.code=='REVOKED'){  
                            document.getElementById("myDiv").innerHTML='已撤銷';  
                            clearInterval(myIntval);
                        }else if(trade_state.code=='USERPAYING'){  
                            document.getElementById("myDiv").innerHTML='用戶支付中';  
                        }else if(trade_state.code=='PAYERROR'){  
                            document.getElementById("myDiv").innerHTML='支付失敗'; 
                            clearInterval(myIntval); 
                        }  
                         
                    }    
                }    
                //orderquery.php 文件返回訂單狀態,經過訂單狀態肯定支付狀態  
                xmlhttp.open("POST","http://www.baidu.com/payment/example/orderquery.php",false);    
                //下面這句話必須有    
                //把標籤/值對添加到要發送的頭文件。    
                xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");    
                xmlhttp.send("out_trade_no="+payOrderCode+"");  
                 
            } 

        }else{
            layer.msg('請求失敗!', {icon: 5}); 
        }
    });
}
</script>
  • 獲取二維碼頁面代碼(此文件須要根據自身狀況進行小小的修改!) getPayQrcode.php

// 放入老衲前不久寫的curl函數 用curl方法獲取二維碼
    function curlGet($url) {  
        $ch = curl_init();  
        curl_setopt($ch, CURLOPT_URL, $url);  
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);   
        curl_setopt($ch, CURLOPT_HEADER, false);  
        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);          
        return curl_exec($ch);  
    }
    // 正式流程開始 返回的二維碼是帶信息的,因此須要先接收商品信息
    // 好比:我是get過來商品的id,然後再進行查詢數據庫;這裏你們隨意;
    $goodsId = $_GET['goodsId'];
    // 利用商品ID查詢到商品名稱和價格
    $goodsName = '好日子牌姨媽巾';
    $goodsPrice = '250';
    // 下面構造請求二維碼的連接(因爲是獲取二維碼支付,因此咋們請求的是native.php;後面會對該文件進行詳細講解)
    $url = 'http://www.baidu.com/payment/example/native.php?goodsName='.$goodsName.'&goodsPrice='.goodsPrice;
    // 執行curlGet()函數
    $data = curlGet($url);
    // preg_match_all函數進行全局正則表達式匹配,獲取到二維碼的連接。 
    preg_match('/<\s*img\s+[^>]*?src\s*=\s*(\'|\")(.*?)\\1[^>]*?\/?\s*>/i',$data,$matches);
    preg_match('/\|\|(.*)\|\|/',$matches[0],$aac);
    // 構造返回信息
    $obj['status'] = 'success';
    $obj['code'] = $aac[1];    // 此值爲返回交易碼【用來確認訂單支付狀態的】
    $obj['price'] = $goodsPrice;
    $obj['msg'] = '/payment/example/'.$matches['2']; // 請求返回的二維碼
    return json_encode($obj);// 返回json
  • 微信支付demo中的掃碼支付文件 payment/example/native.php

<?php
ini_set('date.timezone','Asia/Shanghai');
//error_reporting(E_ERROR);

require_once "../lib/WxPay.Api.php";
require_once "WxPay.NativePay.php";
require_once 'log.php';

//模式一
/**
 * 流程:
 * 一、組裝包含支付信息的url,生成二維碼
 * 二、用戶掃描二維碼,進行支付
 * 三、肯定支付以後,微信服務器會回調預先配置的回調地址,在【微信開放平臺-微信支付-支付配置】中進行配置
 * 四、在接到回調通知以後,用戶進行統一下單支付,並返回支付信息以完成支付(見:native_notify.php)
 * 五、支付完成以後,微信服務器會通知支付成功
 * 六、在支付成功通知中須要查單確認是否真正支付成功(見:notify.php)
 */
$notify = new NativePay();
$url1 = $notify->GetPrePayUrl("123456789");
$goodsPrice = $_GET['goodsPrice'];
$goodsName = $_GET['goodsName'];
// print_r($goodsPrice);die;
//模式二
/**
 * 流程:
 * 一、調用統一下單,取得code_url,生成二維碼
 * 二、用戶掃描二維碼,進行支付
 * 三、支付完成以後,微信服務器會通知支付成功
 * 四、在支付成功通知中須要查單確認是否真正支付成功(見:notify.php)
 */
$input = new WxPayUnifiedOrder();
$input->SetBody($goodsName);
$input->SetAttach("今知商城");
$num = WxPayConfig::MCHID.date("YmdHis");
$input->SetOut_trade_no($num);
$input->SetTotal_fee($goodsPrice*100);
$input->SetTime_start(date("YmdHis"));
$input->SetTime_expire(date("YmdHis", time() + 600));
$input->SetGoods_tag($goodsName);
$input->SetNotify_url("/payment/example/notify.php");
$input->SetTrade_type("NATIVE");
$input->SetProduct_id("123456789");
$result = $notify->GetPayUrl($input);
//echo "<pre>";
//print_r($result);
$url2 = $result["code_url"];
?>

<html>
<head>
    <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
    <meta name="viewport" content="width=device-width, initial-scale=1" /> 
    <title>微信支付樣例</title>
</head>
<body>
    <div style="margin-left: 10px;color:#556B2F;font-size:30px;font-weight: bolder;">掃描支付模式二</div><br/>
    <img alt="||<?php echo $num?>||" src="qrcode.php?data=<?php echo urlencode($url2);?>" style="width:150px;height:150px;"/>
    <div id="myDiv"></div><div id="timer">0</div>
    <script>  
    //設置每隔1000毫秒執行一次load() 方法  
    var myIntval=setInterval(function(){load()},1000);  
    function load(){  
       document.getElementById("timer").innerHTML=parseInt(document.getElementById("timer").innerHTML)+1; 
        var xmlhttp;    
        if (window.XMLHttpRequest){    
            // code for IE7+, Firefox, Chrome, Opera, Safari    
            xmlhttp=new XMLHttpRequest();    
        }else{    
            // code for IE6, IE5    
            xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");    
        }    
        xmlhttp.onreadystatechange=function(){    
            if (xmlhttp.readyState==4 && xmlhttp.status==200){    
                trade_state=xmlhttp.responseText;  
                if(trade_state=='SUCCESS'){  
                    document.getElementById("myDiv").innerHTML='支付成功';  
                    //alert(transaction_id);  
                    //延遲3000毫秒執行tz() 方法
                    clearInterval(myIntval);  
                    setTimeout("location.href='success.php'",3000);  

                }else if(trade_state=='REFUND'){  
                    document.getElementById("myDiv").innerHTML='轉入退款'; 
                    clearInterval(myIntval); 
                }else if(trade_state=='NOTPAY'){  
                    document.getElementById("myDiv").innerHTML='請掃碼支付';  
                      
                }else if(trade_state=='CLOSED'){  
                    document.getElementById("myDiv").innerHTML='已關閉';  
                    clearInterval(myIntval);
                }else if(trade_state=='REVOKED'){  
                    document.getElementById("myDiv").innerHTML='已撤銷';  
                    clearInterval(myIntval);
                }else if(trade_state=='USERPAYING'){  
                    document.getElementById("myDiv").innerHTML='用戶支付中';  
                }else if(trade_state=='PAYERROR'){  
                    document.getElementById("myDiv").innerHTML='支付失敗'; 
                    clearInterval(myIntval); 
                }  
                 
            }    
        }    
        //orderquery.php 文件返回訂單狀態,經過訂單狀態肯定支付狀態  
        xmlhttp.open("POST","orderquery.php",false);    
        //下面這句話必須有    
        //把標籤/值對添加到要發送的頭文件。    
        xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");    
        xmlhttp.send("out_trade_no=<?php echo $num;?>");  
         
        }  
    </script>
    
</body>
  • 微信支付demo 訂單查詢頁面

<?php
header("Access-Control-Allow-Origin:*"); 
ini_set('date.timezone','Asia/Shanghai');
error_reporting(E_ERROR);
require_once "../lib/WxPay.Api.php";
require_once 'log.php';
 
//初始化日誌
$logHandler= new CLogFileHandler("./logs/".date('Y-m-d').'.log');
$log = Log::Init($logHandler, 15);
 
function printf_info($data)
{
    foreach($data as $key=>$value){
        echo "<font color='#f00;'>$key</font> : $value <br/>";
    }
}
 
 
if(isset($_REQUEST["transaction_id"]) && $_REQUEST["transaction_id"] != ""){
    $transaction_id = $_REQUEST["transaction_id"];
    $input = new WxPayOrderQuery();
    $input->SetTransaction_id($transaction_id);
    //printf_info(WxPayApi::orderQuery($input));
    $result=WxPayApi::orderQuery($input);
    echo $result['trade_state'];
    exit();
}
 
if(isset($_REQUEST["out_trade_no"]) && $_REQUEST["out_trade_no"] != ""){
    $out_trade_no = $_REQUEST["out_trade_no"];
    $input = new WxPayOrderQuery();
    $input->SetOut_trade_no($out_trade_no);
    //printf_info(WxPayApi::orderQuery($input));
    $result=WxPayApi::orderQuery($input);
    $status['code'] =  $result['trade_state'];
    $status['openid'] =  $result['openid'];
    $status['total_fee'] =  $result['total_fee'];
    $status['transaction_id'] =  $result['transaction_id'];
    $status['time'] =  $result['time_end'];
    //print_r($result);
    print_r(json_encode($status));
    exit();
}
?>
寫的太差,請見諒;遇到問題了!~搜索QQ羣:phpcode【老司機邪會】羣號:202692399 擼主正是羣主大大。美女進來享受擼主親自一對一貼身手把手指導!

Wishes everybody to be happy everyday!ok,bye!擼主要給客戶繼續寫東西了!~不然明天揭不開鍋了!

相關文章
相關標籤/搜索