麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > PHP > 正文

PHP微信支付實例解析

2020-03-22 20:02:22
字體:
來源:轉載
供稿:網(wǎng)友
本文為大家分享了PHP微信支付實例,包括PHP微信支付源碼,PHP微信退款源碼,php微信支付接口,供大家參考,具體內容如下1.JSapi支付demo(在微信客戶端中點擊) * JS_API支付demo * ==================================================== * 在微信瀏覽器里面打開H5網(wǎng)頁中執(zhí)行JS調起支付。接口輸入輸出數(shù)據(jù)格式為JSON。 * 成功調起支付需要三個步驟: * 步驟1:網(wǎng)頁授權獲取用戶openid * 步驟2:使用統(tǒng)一支付接口,獲取prepay_id * 步驟3:使用jsapi調起支付 include_once("../WxPayPubHelper/WxPayPubHelper.php"); //使用jsapi接口 $jsApi = new JsApi_pub(); //=========步驟1:網(wǎng)頁授權獲取用戶openid============ //通過code獲得openid if (!isset($_GET['code'])) //觸發(fā)微信返回code碼 $url = $jsApi- createOauthUrlForCode(WxPayConf_pub::JS_API_CALL_URL); Header("Location: $url"); }else //獲取code碼,以獲取openid $code = $_GET['code']; $jsApi- setCode($code); $openid = $jsApi- getOpenId(); //=========步驟2:使用統(tǒng)一支付接口,獲取prepay_id============ //使用統(tǒng)一支付接口 $unifiedOrder = new UnifiedOrder_pub(); //設置統(tǒng)一支付接口參數(shù) //設置必填參數(shù) //appid已填,商戶無需重復填寫 //mch_id已填,商戶無需重復填寫 //noncestr已填,商戶無需重復填寫 //spbill_create_ip已填,商戶無需重復填寫 //sign已填,商戶無需重復填寫 $unifiedOrder- setParameter("openid","$openid");//商品描述 $unifiedOrder- setParameter("body","貢獻一分錢");//商品描述 //自定義訂單號,此處僅作舉例 $timeStamp = time(); $out_trade_no = WxPayConf_pub::APPID."$timeStamp"; $unifiedOrder- setParameter("out_trade_no","$out_trade_no");//商戶訂單號 $unifiedOrder- setParameter("total_fee","1");//總金額 $unifiedOrder- setParameter("notify_url",WxPayConf_pub::NOTIFY_URL);//通知地址 $unifiedOrder- setParameter("trade_type","JSAPI");//交易類型 //非必填參數(shù),商戶可根據(jù)實際情況選填 //$unifiedOrder- setParameter("sub_mch_id","XXXX");//子商戶號 //$unifiedOrder- setParameter("device_info","XXXX");//設備號 //$unifiedOrder- setParameter("attach","XXXX");//附加數(shù)據(jù) //$unifiedOrder- setParameter("time_start","XXXX");//交易起始時間 //$unifiedOrder- setParameter("time_expire","XXXX");//交易結束時間 //$unifiedOrder- setParameter("goods_tag","XXXX");//商品標記 //$unifiedOrder- setParameter("openid","XXXX");//用戶標識 //$unifiedOrder- setParameter("product_id","XXXX");//商品ID $prepay_id = $unifiedOrder- getPrepayId(); //=========步驟3:使用jsapi調起支付============ $jsApi- setPrepayId($prepay_id); $jsApiParameters = $jsApi- getParameters(); //echo $jsApiParameters;
* ==================================================== * 模式一:商戶按固定格式生成鏈接二維碼,用戶掃碼后調微信 * 會將productid和用戶openid發(fā)送到商戶設置的鏈接上,商戶收到 * 請求生成訂單,調用統(tǒng)一支付接口下單提交到微信,微信會返回 * 給商戶prepayid。 * 本例程對應的二維碼由native_call_qrcode.php生成; * 本例程對應的響應服務為native_call.php; * 需要兩者配合使用。 include_once("../WxPayPubHelper/WxPayPubHelper.php"); //設置靜態(tài)鏈接 $nativeLink = new NativeLink_pub(); //設置靜態(tài)鏈接參數(shù) //設置必填參數(shù) //appid已填,商戶無需重復填寫 //mch_id已填,商戶無需重復填寫 //noncestr已填,商戶無需重復填寫 //time_stamp已填,商戶無需重復填寫 //sign已填,商戶無需重復填寫 $product_id = WxPayConf_pub::APPID."html' target='_blank'>static";//自定義商品id $nativeLink- setParameter("product_id","$product_id");//商品id //獲取鏈接 $product_url = $nativeLink- getUrl(); //使用短鏈接轉換接口 $shortUrl = new ShortUrl_pub(); //設置必填參數(shù) //appid已填,商戶無需重復填寫 //mch_id已填,商戶無需重復填寫 //noncestr已填,商戶無需重復填寫 //sign已填,商戶無需重復填寫 $shortUrl- setParameter("long_url","$product_url");//URL鏈接 //獲取短鏈接 $codeUrl = $shortUrl- getShortUrl();
* Native(原生)支付-模式二-demo * ==================================================== * 商戶生成訂單,先調用統(tǒng)一支付接口獲取到code_url, * 此URL直接生成二維碼,用戶掃碼后調起支付。 include_once("../WxPayPubHelper/WxPayPubHelper.php"); //使用統(tǒng)一支付接口 $unifiedOrder = new UnifiedOrder_pub(); //設置統(tǒng)一支付接口參數(shù) //設置必填參數(shù) //appid已填,商戶無需重復填寫 //mch_id已填,商戶無需重復填寫 //noncestr已填,商戶無需重復填寫 //spbill_create_ip已填,商戶無需重復填寫 //sign已填,商戶無需重復填寫 $unifiedOrder- setParameter("body","貢獻一分錢");//商品描述 //自定義訂單號,此處僅作舉例 $timeStamp = time(); $out_trade_no = WxPayConf_pub::APPID."$timeStamp"; $unifiedOrder- setParameter("out_trade_no","$out_trade_no");//商戶訂單號 $unifiedOrder- setParameter("total_fee","1");//總金額 $unifiedOrder- setParameter("notify_url",WxPayConf_pub::NOTIFY_URL);//通知地址 $unifiedOrder- setParameter("trade_type","NATIVE");//交易類型 //非必填參數(shù),商戶可根據(jù)實際情況選填 //$unifiedOrder- setParameter("sub_mch_id","XXXX");//子商戶號 //$unifiedOrder- setParameter("device_info","XXXX");//設備號 //$unifiedOrder- setParameter("attach","XXXX");//附加數(shù)據(jù) //$unifiedOrder- setParameter("time_start","XXXX");//交易起始時間 //$unifiedOrder- setParameter("time_expire","XXXX");//交易結束時間 //$unifiedOrder- setParameter("goods_tag","XXXX");//商品標記 //$unifiedOrder- setParameter("openid","XXXX");//用戶標識 //$unifiedOrder- setParameter("product_id","XXXX");//商品ID //獲取統(tǒng)一支付接口結果 $unifiedOrderResult = $unifiedOrder- getResult(); //商戶根據(jù)實際情況設置相應的處理流程 if ($unifiedOrderResult["return_code"] == "FAIL") //商戶自行增加處理流程 echo "通信出錯:".$unifiedOrderResult['return_msg']." br elseif($unifiedOrderResult["result_code"] == "FAIL") //商戶自行增加處理流程 echo "錯誤代碼:".$unifiedOrderResult['err_code']." br echo "錯誤代碼描述:".$unifiedOrderResult['err_code_des']." br elseif($unifiedOrderResult["code_url"] != NULL) //從統(tǒng)一支付接口獲取到code_url $code_url = $unifiedOrderResult["code_url"]; //商戶自行增加處理流程 //......
* ==================================================== * 該接口提供所有微信支付訂單的查詢。 * 當支付通知處理異常或丟失的情況,商戶可以通過該接口查詢訂單支付狀態(tài)。 include_once("../WxPayPubHelper/WxPayPubHelper.php"); //退款的訂單號 if (!isset($_POST["out_trade_no"])) $out_trade_no = " "; }else{ $out_trade_no = $_POST["out_trade_no"]; //使用訂單查詢接口 $orderQuery = new OrderQuery_pub(); //設置必填參數(shù) //appid已填,商戶無需重復填寫 //mch_id已填,商戶無需重復填寫 //noncestr已填,商戶無需重復填寫 //sign已填,商戶無需重復填寫 $orderQuery- setParameter("out_trade_no","$out_trade_no");//商戶訂單號 //非必填參數(shù),商戶可根據(jù)實際情況選填 //$orderQuery- setParameter("sub_mch_id","XXXX");//子商戶號 //$orderQuery- setParameter("transaction_id","XXXX");//微信訂單號 //獲取訂單查詢結果 $orderQueryResult = $orderQuery- getResult(); //商戶根據(jù)實際情況設置相應的處理流程,此處僅作舉例 if ($orderQueryResult["return_code"] == "FAIL") { echo "通信出錯:".$orderQueryResult['return_msg']." br elseif($orderQueryResult["result_code"] == "FAIL"){ echo "錯誤代碼:".$orderQueryResult['err_code']." br echo "錯誤代碼描述:".$orderQueryResult['err_code_des']." br else{ echo "交易狀態(tài):".$orderQueryResult['trade_state']." br echo "設備號:".$orderQueryResult['device_info']." br echo "用戶標識:".$orderQueryResult['openid']." br echo "是否關注公眾賬號:".$orderQueryResult['is_subscribe']." br echo "交易類型:".$orderQueryResult['trade_type']." br echo "付款銀行:".$orderQueryResult['bank_type']." br echo "總金額:".$orderQueryResult['total_fee']." br echo "現(xiàn)金券金額:".$orderQueryResult['coupon_fee']." br echo "貨幣種類:".$orderQueryResult['fee_type']." br echo "微信支付訂單號:".$orderQueryResult['transaction_id']." br echo "商戶訂單號:".$orderQueryResult['out_trade_no']." br echo "商家數(shù)據(jù)包:".$orderQueryResult['attach']." br echo "支付完成時間:".$orderQueryResult['time_end']." br //商戶自行增加處理流程 //......
* ==================================================== * 商戶可以通過該接口下載歷史交易清單。 include_once("../WxPayPubHelper/WxPayPubHelper.php"); //對賬單日期 if (!isset($_POST["bill_date"])){ $bill_date = "20140814"; else{ $bill_date = $_POST["bill_date"]; //使用對賬單接口 $downloadBill = new DownloadBill_pub(); //設置對賬單接口參數(shù) //設置必填參數(shù) //appid已填,商戶無需重復填寫 //mch_id已填,商戶無需重復填寫 //noncestr已填,商戶無需重復填寫 //sign已填,商戶無需重復填寫 $downloadBill- setParameter("bill_date","$bill_date");//對賬單日期 $downloadBill- setParameter("bill_type","ALL");//賬單類型 //非必填參數(shù),商戶可根據(jù)實際情況選填 //$downloadBill- setParameter("device_info","XXXX");//設備號 //對賬單接口結果 $downloadBillResult = $downloadBill- getResult(); echo $downloadBillResult['return_code']; if ($downloadBillResult['return_code'] == "FAIL") { echo "通信出錯:".$downloadBillResult['return_msg']; }else{ print_r(' pre echo "【對賬單詳情】"." /br print_r($downloadBill- response); print_r(' /pre
* ==================================================== * 注意:同一筆單的部分退款需要設置相同的訂單號和不同的 * out_refund_no。一筆退款失敗后重新提交,要采用原來的 * out_refund_no。總退款金額不能超過用戶實際支付金額(現(xiàn) * 金券金額不能退款)。 include_once("../WxPayPubHelper/WxPayPubHelper.php"); //輸入需退款的訂單號 if (!isset($_POST["out_trade_no"]) || !isset($_POST["refund_fee"])) $out_trade_no = " "; $refund_fee = "1"; }else{ $out_trade_no = $_POST["out_trade_no"]; $refund_fee = $_POST["refund_fee"]; //商戶退款單號,商戶自定義,此處僅作舉例 $out_refund_no = "$out_trade_no"."$time_stamp"; //總金額需與訂單號out_trade_no對應,demo中的所有訂單的總金額為1分 $total_fee = "1"; //使用退款接口 $refund = new Refund_pub(); //設置必填參數(shù) //appid已填,商戶無需重復填寫 //mch_id已填,商戶無需重復填寫 //noncestr已填,商戶無需重復填寫 //sign已填,商戶無需重復填寫 $refund- setParameter("out_trade_no","$out_trade_no");//商戶訂單號 $refund- setParameter("out_refund_no","$out_refund_no");//商戶退款單號 $refund- setParameter("total_fee","$total_fee");//總金額 $refund- setParameter("refund_fee","$refund_fee");//退款金額 $refund- setParameter("op_user_id",WxPayConf_pub::MCHID);//操作員 //非必填參數(shù),商戶可根據(jù)實際情況選填 //$refund- setParameter("sub_mch_id","XXXX");//子商戶號 //$refund- setParameter("device_info","XXXX");//設備號 //$refund- setParameter("transaction_id","XXXX");//微信訂單號 //調用結果 $refundResult = $refund- getResult(); //商戶根據(jù)實際情況設置相應的處理流程,此處僅作舉例 if ($refundResult["return_code"] == "FAIL") { echo "通信出錯:".$refundResult['return_msg']." br else{ echo "業(yè)務結果:".$refundResult['result_code']." br echo "錯誤代碼:".$refundResult['err_code']." br echo "錯誤代碼描述:".$refundResult['err_code_des']." br echo "公眾賬號ID:".$refundResult['appid']." br echo "商戶號:".$refundResult['mch_id']." br echo "子商戶號:".$refundResult['sub_mch_id']." br echo "設備號:".$refundResult['device_info']." br echo "簽名:".$refundResult['sign']." br echo "微信訂單號:".$refundResult['transaction_id']." br echo "商戶訂單號:".$refundResult['out_trade_no']." br echo "商戶退款單號:".$refundResult['out_refund_no']." br echo "微信退款單號:".$refundResult['refund_idrefund_id']." br echo "退款渠道:".$refundResult['refund_channel']." br echo "退款金額:".$refundResult['refund_fee']." br echo "現(xiàn)金券退款金額:".$refundResult['coupon_refund_fee']." br
//sign已填,商戶無需重復填寫 $refundQuery- setParameter("out_trade_no","$out_trade_no");//商戶訂單號 // $refundQuery- setParameter("out_refund_no","XXXX");//商戶退款單號 // $refundQuery- setParameter("refund_id","XXXX");//微信退款單號 // $refundQuery- setParameter("transaction_id","XXXX");//微信退款單號 //非必填參數(shù),商戶可根據(jù)實際情況選填 //$refundQuery- setParameter("sub_mch_id","XXXX");//子商戶號 //$refundQuery- setParameter("device_info","XXXX");//設備號 //退款查詢接口結果 $refundQueryResult = $refundQuery- getResult(); //商戶根據(jù)實際情況設置相應的處理流程,此處僅作舉例 if ($refundQueryResult["return_code"] == "FAIL") { echo "通信出錯:".$refundQueryResult['return_msg']." br else{ echo "業(yè)務結果:".$refundQueryResult['result_code']." br echo "錯誤代碼:".$refundQueryResult['err_code']." br echo "錯誤代碼描述:".$refundQueryResult['err_code_des']." br echo "公眾賬號ID:".$refundQueryResult['appid']." br echo "商戶號:".$refundQueryResult['mch_id']." br echo "子商戶號:".$refundQueryResult['sub_mch_id']." br echo "設備號:".$refundQueryResult['device_info']." br echo "簽名:".$refundQueryResult['sign']." br echo "微信訂單號:".$refundQueryResult['transaction_id']." br echo "商戶訂單號:".$refundQueryResult['out_trade_no']." br echo "退款筆數(shù):".$refundQueryResult['refund_count']." br echo "商戶退款單號:".$refundQueryResult['out_refund_no']." br echo "微信退款單號:".$refundQueryResult['refund_idrefund_id']." br echo "退款渠道:".$refundQueryResult['refund_channel']." br echo "退款金額:".$refundQueryResult['refund_fee']." br echo "現(xiàn)金券退款金額:".$refundQueryResult['coupon_refund_fee']." br echo "退款狀態(tài):".$refundQueryResult['refund_status']." br
微信支付源碼下載以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持phpstudy。PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 成人做爰s片免费看网站 | 欧美综合在线观看视频 | 欧美视频国产精品 | 成人免费一区二区 | 91短视频免费 | 久久久久国产一区二区三区不卡 | 国产精品久久久久久久久久久久久久久久 | 日韩av电影免费在线观看 | 久久久久久久久久久久久久av | 中文字幕免费看 | 做爰裸体激情2 | 国产不卡av在线 | 午夜视频色 | 免费嗨片首页中文字幕 | 免费专区 - 91爱爱 | 亚洲成人免费影视 | 国产亚色 | 中文区永久区 | 美国一级毛片片aa久久综合 | 欧美日韩免费观看视频 | 久久91久久 | 免费色片| 天天看成人免费毛片视频 | 欧美精品一区二区久久 | 鲁人人人鲁人人鲁精品 | 日日操夜夜透 | 国产午夜精品一区二区三区视频 | 国产人妖一区二区 | 成熟女人特级毛片www免费 | 亚洲天堂成人在线 | av手机在线免费播放 | 久草久视频 | 免费成人| 在线播放91| 1级黄色毛片| 在线视频观看国产 | 偿还电影免费看 | 成人福利电影在线观看 | 国产小视频在线 | 九九视频精品在线观看 | 国产一级做a爰片在线看 |