中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP微信支付開發之掃描支付后回調的示例分析

發布時間:2021-09-03 10:46:18 來源:億速云 閱讀:142 作者:小新 欄目:移動開發

這篇文章主要介紹了PHP微信支付開發之掃描支付后回調的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

一、下載微信支付SDK

下載SDK包后解壓,在解壓目錄下,我們會看到如下目錄

PHP微信支付開發之掃描支付后回調的示例分析

二、查閱微信支付開發者文檔后得知,微信掃碼支付的demo即為example目錄下的native.php文件

為了方便,我們要做的是將整個解壓后的文件放入到本地環境的根目錄下的wxpay(可隨個人喜好命名)文件夾中

三、以筆者為例,在瀏覽器中輸入http://localhost/wxpay/example/native.php

打開上面網址后,發現有兩個二維碼,如題,我們今天研究的是模式二掃碼(官方也推薦模式二掃碼支付)

四、我們用手機登陸微信,掃描上面頁面中的模式二的二維碼,并且支付

在這里我們發現一個有趣的問題,當你支付成功后,PC頁面中并沒有發生任何變化,所以我們考慮的主要問題是,支付后如何進行回調。

這里不說多的廢話了,筆者參考了網上的諸多方法,總結如下:

1、刪掉native.php文件中掃碼模式一的一些html,只剩下掃碼模式二的一些相關html代碼。

2、由于官方文檔中也說明了,掃碼模式二的支付結果是異步響應,不會主動返回支付結果,所以我們采用了javascript去時時監聽支付結果,然后根據請求的結果,在做下一步的頁面回調。筆者最終代碼如下,有興趣的朋友可以參考下:

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';

//模式一
/**
 * 流程:
 * 1、組裝包含支付信息的url,生成二維碼
 * 2、用戶掃描二維碼,進行支付
 * 3、確定支付之后,微信服務器會回調預先配置的回調地址,在【微信開放平臺-微信支付-支付配置】中進行配置
 * 4、在接到回調通知之后,用戶進行統一下單支付,并返回支付信息以完成支付(見:native_notify.php)
 * 5、支付完成之后,微信服務器會通知支付成功
 * 6、在支付成功通知中需要查單確認是否真正支付成功(見:notify.php)
 */
$notify = new NativePay();
$url1 = $notify->GetPrePayUrl("123456789");

//模式二
/**
 * 流程:
 * 1、調用統一下單,取得code_url,生成二維碼
 * 2、用戶掃描二維碼,進行支付
 * 3、支付完成之后,微信服務器會通知支付成功
 * 4、在支付成功通知中需要查單確認是否真正支付成功(見:notify.php)
 */
$input = new WxPayUnifiedOrder();
$input->SetBody("1分錢購買何寧");
$input->SetAttach("1分錢購買何寧");
$num=WxPayConfig::MCHID.date("YmdHis");
$input->SetOut_trade_no($num);
$input->SetTotal_fee("1");
$input->SetTime_start(date("YmdHis"));
$input->SetTime_expire(date("YmdHis", time() + 600));
$input->SetGoods_tag("test");
$input->SetNotify_url("http://paysdk.weixin.qq.com/example/notify.php");
$input->SetTrade_type("NATIVE");
$input->SetProduct_id("123456789");
$result = $notify->GetPayUrl($input);
$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="模式二掃碼支付" 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>
</html>

orderquery.php代碼也做了相應調整:

<?php
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);
    echo $result['trade_state'];
    exit();
}
?>

新建success.php文件:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>微信支付成功</title>
</head>
 
<body>
<br /><br /><br /><br /><br /><br /><br />
<h2>微信支付成功</h2>
</body>
</html>

感謝你能夠認真閱讀完這篇文章,希望小編分享的“PHP微信支付開發之掃描支付后回調的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

盐山县| 土默特右旗| 容城县| 密云县| 临朐县| SHOW| 明星| 西城区| 客服| 洛浦县| 荥经县| 龙里县| 团风县| 平度市| 临城县| 化隆| 泾阳县| 惠来县| 龙泉市| 霍邱县| 富民县| 望奎县| 贵南县| 肇东市| 日照市| 贵定县| 砚山县| 望都县| 五原县| 平果县| 崇阳县| 射洪县| 南部县| 德州市| 临泽县| 九台市| 长阳| 罗甸县| 南岸区| 象山县| 鹿泉市|