博主写这破玩意儿的时候花了大概快两天时间才整体的弄懂逻辑,考虑了一下~还是把所有代码都放出来给大家~抱着开源大无私的精神!谁叫我擅长拍黄片呢?同时也感谢我刚入行时候那些无私帮过我的程序员们!

  • 首先还是先给大家上效果图吧(样式我也会一并给大家的,漂亮吧?骚年们!)!


  • 各位骚年们~请不要着急往下看代码,先给大家解释怎么获取到的二维码

上面的这图,用到了Jquery,Layer这两个js,大家请自己下载一下(链接自己点文字就行)。

整个流程简绍:点击支付后调用layer弹出窗口->ajax获取支付的二维码->轮询支付状态!

补充!不要当心轮询占用服务器资源的问题~因为假如同时有上万人等着支付的话,我相信你公司不会缺服务器这点小钱了!所以放心用吧!另外~按照我的逻辑来说应该是非常安全。请大家耐心看下去,虽然代码拿去就能用!但还是希望授之以渔!

ok!下面正式开始了哟!~大家注意仔细阅读代码。


第一步 首先把官方的微信demo下载下来进行配置部署

给大家个传送门-> PHP微信支付demo下载

  1. 拿到文件后解压,解压后把文件夹改名为payment(也可以随意改,但是博主觉得这样规范点!)而后上传至项目的根目录,各位大佬不知道什么是根目录就请看这(/).其实我是逗你们的。
  2. 而后进入微信的商户后台,设置apikey注意看下图(网上随意找的~丑了点,将就吧!)设置完后,下载证书文件。而后把证书解压出来!放到微信支付demo里面,也就是上一步上传服务器的demo文件夹中!下面是详细步骤:
  1. 设置密钥(如图)

  2. 下载证书,得到压缩文件夹,解压后上传到payment中的cert中!(如图,图上有路径)

  3. 在此顺便给logs文件夹(支付日志)一个写入的权限

  4. 修改微信支付demo中的配置文件WxPay.Config.php(如图:路径)

  1. //只用修改第25、26、27、28行(示例)
  2. const APPID = 'wx2a3f1e5246886123'; //微信公众号的APPID
  3. const MCHID = '1300778123'; //微信商户号
  4. const KEY = '619fd0f3f9c64550964bbe5b94dba123'; //微信商户密钥(上面步骤中设置的那个)
  5. const APPSECRET = '5c8289b72600936f813ec1939e68f123'; //微信公众号的APPSECRET

第一步分的配置咋们就完成了,请各位大佬继续跟着小的往下走!

第二部 调整前段代码 大部分都是JS,不懂JS得直接略过吧,否则看着难受!

  1. 对于点击后弹出支付的这一块逻辑,撸主的思路是:点击支付按钮->执行Ajax获取到二维码展示在页面->开始执行轮询获取支付状态;(撸主虽然JS很菜,但是每一条代码后面都会注释给大家,比我菜的可以看一下)
  • 创建获取二维码的文件 getPayQrcode.php

  1. <?php
  2. // 放入老衲前不久写的curl函数 用curl方法获取二维码
  3. function curlGet($url) {
  4. $ch = curl_init();
  5. curl_setopt($ch, CURLOPT_URL, $url);
  6. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  7. curl_setopt($ch, CURLOPT_HEADER, false);
  8. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
  9. return curl_exec($ch);
  10. }
  11. // 正式流程开始 返回的二维码是带信息的,所以需要先接收商品信息
  12. // 比如:我是get过来商品的id,而后再进行查询数据库;这里大家随意;
  13. $goodsId = $_GET['goodsId'];
  14. // 利用商品ID查询到商品名称和价格
  15. $goodsName = '好日子牌姨妈巾';
  16. $goodsPrice = '250';
  17. // 下面构造请求二维码的链接(由于是获取二维码支付,所以咋们请求的是native.php;后面会对该文件进行详细讲解)
  18. $url = 'http://www.baidu.com/payment/example/native.php?goodsName='.$goodsName.'&goodsPrice='.goodsPrice;
  19. // 执行curlGet()函数
  20. $data = curlGet($url);
  21. // preg_match_all函数进行全局正则表达式匹配,获取到二维码的链接。
  22. preg_match('/<\s*img\s+[^>]*?src\s*=\s*(\'|\")(.*?)\\1[^>]*?\/?\s*>/i',$data,$matches);
  23. preg_match('/\|\|(.*)\|\|/',$matches[0],$aac);
  24. // 构造返回信息
  25. $obj['status'] = 'success';
  26. $obj['code'] = $aac[1]; // 此值为返回交易码【用来确认订单支付状态的】
  27. $obj['price'] = $goodsPrice;
  28. $obj['msg'] = '/payment/example/'.$matches['2']; // 请求返回的二维码
  29. return json_encode($obj);// 返回json
  30. // 获取二维码的文件已经ok!继续下一步
  • 设置微信支付demo中的扫码支付文件 payment/example/native.php

  1. //在大概19行找到该代码 $notify = new NativePay(); 并在下方添加获取商品名字和商品价格的代码
  2. // 接收get过来的商品价格和名称
  3. $goodsPrice = $_GET['goodsPrice'];
  4. $goodsName = $_GET['goodsName'];
  5. //下面修改从第32号开始的一大堆$input开头的
  6. $input = new WxPayUnifiedOrder();
  7. $input->SetBody($goodsName);//商品名称
  8. $input->SetAttach("大姨妈商城");//自己设置
  9. $num = WxPayConfig::MCHID.date("YmdHis");//订单号
  10. $input->SetOut_trade_no($num);
  11. $input->SetTotal_fee($goodsPrice*100);//注意!!!!!!!!!由于是以分为单位结算,所以一定要记得商品价格*100;别到时候下岗了来怪撸主
  12. $input->SetTime_start(date("YmdHis"));
  13. $input->SetTime_expire(date("YmdHis", time() + 600));
  14. $input->SetGoods_tag($goodsName);//下面的这些参数大家自己看一下文档吧!意义都不大,撸主肾虚,要早点写完早点睡!
  15. $input->SetNotify_url("/payment/example/notify.php");
  16. $input->SetTrade_type("NATIVE");
  17. $input->SetProduct_id("123456789");
  18. $result = $notify->GetPayUrl($input);
  19. //print_r($result);//最终的信息,大家可以打印了进行调试
  20. $url2 = $result["code_url"];
  21. // ok!整个文件的PHP代码就完毕了!在这以下的html代码全部把它干掉,把撸主准备的这段贴上去 这段代码不做什么解释了,也是用于查询订单状态的轮询,调试用的~!下面还会用到一次,讲的很详细
  22. <html>
  23. <head>
  24. <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
  25. <meta name="viewport" content="width=device-width, initial-scale=1" />
  26. <title>微信支付样例</title>
  27. </head>
  28. <body>
  29. <div style="margin-left: 10px;color:#556B2F;font-size:30px;font-weight: bolder;">扫描支付模式二</div><br/>
  30. <img alt="||<?php echo $num?>||" src="qrcode.php?data=<?php echo urlencode($url2);?>" style="width:150px;height:150px;"/>
  31. <div id="myDiv"></div><div id="timer">0</div>
  32. </body>
  33. <script>
  34. //设置每隔1000毫秒执行一次load() 方法
  35. var myIntval=setInterval(function(){load()},1000);
  36. function load(){
  37. document.getElementById("timer").innerHTML=parseInt(document.getElementById("timer").innerHTML)+1;
  38. var xmlhttp;
  39. if (window.XMLHttpRequest){
  40. // code for IE7+, Firefox, Chrome, Opera, Safari
  41. xmlhttp=new XMLHttpRequest();
  42. }else{
  43. // code for IE6, IE5
  44. xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  45. }
  46. xmlhttp.onreadystatechange=function(){
  47. if (xmlhttp.readyState==4 && xmlhttp.status==200){
  48. trade_state=xmlhttp.responseText;
  49. if(trade_state=='SUCCESS'){
  50. document.getElementById("myDiv").innerHTML='支付成功';
  51. //alert(transaction_id);
  52. //延迟3000毫秒执行tz() 方法
  53. clearInterval(myIntval);
  54. setTimeout("location.href='success.php'",3000);
  55. }else if(trade_state=='REFUND'){
  56. document.getElementById("myDiv").innerHTML='转入退款';
  57. clearInterval(myIntval);
  58. }else if(trade_state=='NOTPAY'){
  59. document.getElementById("myDiv").innerHTML='请扫码支付';
  60. }else if(trade_state=='CLOSED'){
  61. document.getElementById("myDiv").innerHTML='已关闭';
  62. clearInterval(myIntval);
  63. }else if(trade_state=='REVOKED'){
  64. document.getElementById("myDiv").innerHTML='已撤销';
  65. clearInterval(myIntval);
  66. }else if(trade_state=='USERPAYING'){
  67. document.getElementById("myDiv").innerHTML='用户支付中';
  68. }else if(trade_state=='PAYERROR'){
  69. document.getElementById("myDiv").innerHTML='支付失败';
  70. clearInterval(myIntval);
  71. }
  72. }
  73. }
  74. //orderquery.php 文件返回订单状态,通过订单状态确定支付状态
  75. xmlhttp.open("POST","orderquery.php",false);
  76. //下面这句话必须有
  77. //把标签/值对添加到要发送的头文件。
  78. xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
  79. xmlhttp.send("out_trade_no=<?php echo $num;?>");
  80. }
  81. </script>
  • 微信支付demo订单查询文件 payment/example/orderquery.php

  1. header("Access-Control-Allow-Origin:*"); // 因为撸主的支付实在另外一台服务器上,所以给了一个域头
  2. ini_set('date.timezone','Asia/Shanghai');// 设置一下时区
  3. error_reporting(E_ERROR); // 关闭报错
  4. require_once "../lib/WxPay.Api.php";
  5. require_once 'log.php';
  6. //初始化日志
  7. $logHandler= new CLogFileHandler("./logs/".date('Y-m-d').'.log');
  8. $log = Log::Init($logHandler, 15);
  9. function printf_info($data)
  10. {
  11. foreach($data as $key=>$value){
  12. echo "<font color='#f00;'>$key</font> : $value <br/>";
  13. }
  14. }
  15. // 一下两个if的判断均为判断订单的状态,这里撸主建议去微信官网进行查阅,下面有传送门送你过去
  16. if(isset($_REQUEST["transaction_id"]) && $_REQUEST["transaction_id"] != ""){
  17. $transaction_id = $_REQUEST["transaction_id"];
  18. $input = new WxPayOrderQuery();
  19. $input->SetTransaction_id($transaction_id);
  20. //printf_info(WxPayApi::orderQuery($input));
  21. $result=WxPayApi::orderQuery($input);
  22. echo $result['trade_state'];
  23. exit();
  24. }
  25. if(isset($_REQUEST["out_trade_no"]) && $_REQUEST["out_trade_no"] != ""){
  26. $out_trade_no = $_REQUEST["out_trade_no"];
  27. $input = new WxPayOrderQuery();
  28. $input->SetOut_trade_no($out_trade_no);
  29. //printf_info(WxPayApi::orderQuery($input));
  30. $result=WxPayApi::orderQuery($input);
  31. $status['code'] = $result['trade_state'];
  32. $status['openid'] = $result['openid'];
  33. $status['total_fee'] = $result['total_fee'];
  34. $status['transaction_id'] = $result['transaction_id'];
  35. $status['time'] = $result['time_end'];
  36. //print_r($result);
  37. print_r(json_encode($status));
  38. exit();
  39. }

传送门 微信返回错误代码解释

  • 点击支付按钮的代码

  1. // 前段代码 样式用大家自己的就行,不用照抄
  2. <div class="goods_btn">
  3. <div class="buy" onclick="GetPay()">立即购买</div>
  4. </div>
  5. // JS代码 js代码中嵌入的样式,无需修改!和效果图一样的!
  6. //接入微信扫码支付
  7. function GetPay() {
  8. // 用ajax获取到支付的二维码
  9. var payQrcode = '';
  10. var payPrice = '';
  11. var payOrderCode = '';
  12. // 执行Ajax请求
  13. $.get('/getPayQrcode.php',{"goodsId":"商品的ID"},function(ret){
  14. var obj = JSON.parse(ret) // 把字符串进行转换
  15. // 判断返回数据是否正常(由于请求一般不会出问题,所以在获取二维码的getPayQrcode.php文件没有写返回fail)
  16. if (obj.status == 'success') {
  17. payQrcode = 'http://www.baidu.com'+obj.msg;//二维码链接
  18. payPrice = obj.price; //商品价格
  19. payOrderCode = obj.code; //交易码
  20. //执行layer弹层
  21. layer.open({
  22. type: 1,
  23. skin: 'layui-layer-demo', //样式类名,随意!
  24. closeBtn: 0, //不显示关闭按钮
  25. title:false, //关闭title部分
  26. anim: 2,
  27. area: ['300px', '450px'], //层的宽高
  28. shadeClose: true, //开启遮罩关闭
  29. 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>'
  30. });
  31. // 轮询代码开始
  32. // 设置每隔1000毫秒执行一次load() 方法
  33. var myIntval=setInterval(function(){load()},1000);
  34. function load(){
  35. var xmlhttp;
  36. // 轮询的浏览器设置
  37. if (window.XMLHttpRequest){
  38. // code for IE7+, Firefox, Chrome, Opera, Safari
  39. xmlhttp=new XMLHttpRequest();
  40. }else{
  41. // code for IE6, IE5
  42. xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  43. }
  44. xmlhttp.onreadystatechange=function(){
  45. if (xmlhttp.readyState==4 && xmlhttp.status==200){
  46. trade_state=JSON.parse(xmlhttp.responseText);
  47. console.log(trade_state);//打印查看轮询的状态,也可以关闭。
  48. //判断订单支付状态 并用document.getElementById方法赋值到myDiv中;
  49. if(trade_state.code=='SUCCESS'){
  50. document.getElementById("myDiv").innerHTML='支付成功';
  51. //延迟3000毫秒执行tz() 方法
  52. clearInterval(myIntval);
  53. //进行跳转。
  54. setTimeout("location.href='./",1500);
  55. }else if(trade_state.code=='REFUND'){
  56. document.getElementById("myDiv").innerHTML='转入退款';
  57. clearInterval(myIntval);
  58. }else if(trade_state.code=='NOTPAY'){
  59. document.getElementById("myDiv").innerHTML='请扫码支付';
  60. }else if(trade_state.code=='CLOSED'){
  61. document.getElementById("myDiv").innerHTML='已关闭';
  62. clearInterval(myIntval);
  63. }else if(trade_state.code=='REVOKED'){
  64. document.getElementById("myDiv").innerHTML='已撤销';
  65. clearInterval(myIntval);
  66. }else if(trade_state.code=='USERPAYING'){
  67. document.getElementById("myDiv").innerHTML='用户支付中';
  68. }else if(trade_state.code=='PAYERROR'){
  69. document.getElementById("myDiv").innerHTML='支付失败';
  70. clearInterval(myIntval);
  71. }
  72. }
  73. }
  74. //orderquery.php 文件返回订单状态,通过订单状态确定支付状态
  75. xmlhttp.open("POST","http://www.baidu.com/payment/example/orderquery.php",false);
  76. //下面这句话必须有
  77. //把标签/值对添加到要发送的头文件。
  78. xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
  79. xmlhttp.send("out_trade_no="+payOrderCode+"");
  80. }
  81. }else{
  82. layer.msg('请求失败!', {icon: 5});
  83. }
  84. });
  85. }
  86. // 上面的这段js代码稍微有点复杂,愿大家耐心看!撸主是js菜鸡、文盲、白痴;大佬们勿喷!
  1. ok!到此为止,整个流程就已经结束了!~上面的代码仅供参考!~下面撸主会贴出整套代码来造福社会!

原装进口代码,麻烦大家记得点赞、关注、收藏,谢谢!

此套代码是原生的php!大家随意用!

  • 调取支付页面代码

  1. <div class="goods_btn">
  2. <div class="buy" onclick="GetPay()">立即购买</div>
  3. </div>
  4. <script type="text/javascript">
  5. //接入微信扫码支付
  6. function GetPay() {
  7. //用ajax获取到支付的二维码
  8. var payQrcode = '';
  9. var payPrice = '';
  10. var payOrderCode = '';
  11. $.get('/getPayQrcode.php',{"goodsId":"<?php echo $goodsInfo->id;?>"},function(ret){
  12. var obj = JSON.parse(ret)
  13. if (obj.status == 'success') {
  14. payQrcode = 'http://www.baidu.com'+obj.msg;
  15. payPrice = obj.price;
  16. payOrderCode = obj.code;
  17. layer.open({
  18. type: 1,
  19. skin: 'layui-layer-demo', //样式类名
  20. closeBtn: 0, //不显示关闭按钮
  21. title:false,
  22. anim: 2,
  23. area: ['300px', '450px'],
  24. shadeClose: true, //开启遮罩关闭
  25. 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>'
  26. });
  27. // 设置每隔1000毫秒执行一次load() 方法
  28. var myIntval=setInterval(function(){load()},1000);
  29. function load(){
  30. //document.getElementById("timer").innerHTML=parseInt(document.getElementById("timer").innerHTML)+1;
  31. var xmlhttp;
  32. if (window.XMLHttpRequest){
  33. // code for IE7+, Firefox, Chrome, Opera, Safari
  34. xmlhttp=new XMLHttpRequest();
  35. }else{
  36. // code for IE6, IE5
  37. xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  38. }
  39. xmlhttp.onreadystatechange=function(){
  40. if (xmlhttp.readyState==4 && xmlhttp.status==200){
  41. trade_state=JSON.parse(xmlhttp.responseText);
  42. console.log(trade_state);
  43. if(trade_state.code=='SUCCESS'){
  44. document.getElementById("myDiv").innerHTML='支付成功';
  45. //alert(transaction_id);
  46. //延迟3000毫秒执行tz() 方法
  47. clearInterval(myIntval);
  48. setTimeout("location.href='./",1500);
  49. }else if(trade_state.code=='REFUND'){
  50. document.getElementById("myDiv").innerHTML='转入退款';
  51. clearInterval(myIntval);
  52. }else if(trade_state.code=='NOTPAY'){
  53. document.getElementById("myDiv").innerHTML='请扫码支付';
  54. }else if(trade_state.code=='CLOSED'){
  55. document.getElementById("myDiv").innerHTML='已关闭';
  56. clearInterval(myIntval);
  57. }else if(trade_state.code=='REVOKED'){
  58. document.getElementById("myDiv").innerHTML='已撤销';
  59. clearInterval(myIntval);
  60. }else if(trade_state.code=='USERPAYING'){
  61. document.getElementById("myDiv").innerHTML='用户支付中';
  62. }else if(trade_state.code=='PAYERROR'){
  63. document.getElementById("myDiv").innerHTML='支付失败';
  64. clearInterval(myIntval);
  65. }
  66. }
  67. }
  68. //orderquery.php 文件返回订单状态,通过订单状态确定支付状态
  69. xmlhttp.open("POST","http://www.baidu.com/payment/example/orderquery.php",false);
  70. //下面这句话必须有
  71. //把标签/值对添加到要发送的头文件。
  72. xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
  73. xmlhttp.send("out_trade_no="+payOrderCode+"");
  74. }
  75. }else{
  76. layer.msg('请求失败!', {icon: 5});
  77. }
  78. });
  79. }
  80. </script>
  • 获取二维码页面代码(此文件需要根据自身情况进行小小的修改!) getPayQrcode.php

  1. // 放入老衲前不久写的curl函数 用curl方法获取二维码
  2. function curlGet($url) {
  3. $ch = curl_init();
  4. curl_setopt($ch, CURLOPT_URL, $url);
  5. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  6. curl_setopt($ch, CURLOPT_HEADER, false);
  7. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
  8. return curl_exec($ch);
  9. }
  10. // 正式流程开始 返回的二维码是带信息的,所以需要先接收商品信息
  11. // 比如:我是get过来商品的id,而后再进行查询数据库;这里大家随意;
  12. $goodsId = $_GET['goodsId'];
  13. // 利用商品ID查询到商品名称和价格
  14. $goodsName = '好日子牌姨妈巾';
  15. $goodsPrice = '250';
  16. // 下面构造请求二维码的链接(由于是获取二维码支付,所以咋们请求的是native.php;后面会对该文件进行详细讲解)
  17. $url = 'http://www.baidu.com/payment/example/native.php?goodsName='.$goodsName.'&goodsPrice='.goodsPrice;
  18. // 执行curlGet()函数
  19. $data = curlGet($url);
  20. // preg_match_all函数进行全局正则表达式匹配,获取到二维码的链接。
  21. preg_match('/<\s*img\s+[^>]*?src\s*=\s*(\'|\")(.*?)\\1[^>]*?\/?\s*>/i',$data,$matches);
  22. preg_match('/\|\|(.*)\|\|/',$matches[0],$aac);
  23. // 构造返回信息
  24. $obj['status'] = 'success';
  25. $obj['code'] = $aac[1]; // 此值为返回交易码【用来确认订单支付状态的】
  26. $obj['price'] = $goodsPrice;
  27. $obj['msg'] = '/payment/example/'.$matches['2']; // 请求返回的二维码
  28. return json_encode($obj);// 返回json
  • 微信支付demo中的扫码支付文件 payment/example/native.php

  1. <?php
  2. ini_set('date.timezone','Asia/Shanghai');
  3. //error_reporting(E_ERROR);
  4. require_once "../lib/WxPay.Api.php";
  5. require_once "WxPay.NativePay.php";
  6. require_once 'log.php';
  7. //模式一
  8. /**
  9. * 流程:
  10. * 1、组装包含支付信息的url,生成二维码
  11. * 2、用户扫描二维码,进行支付
  12. * 3、确定支付之后,微信服务器会回调预先配置的回调地址,在【微信开放平台-微信支付-支付配置】中进行配置
  13. * 4、在接到回调通知之后,用户进行统一下单支付,并返回支付信息以完成支付(见:native_notify.php)
  14. * 5、支付完成之后,微信服务器会通知支付成功
  15. * 6、在支付成功通知中需要查单确认是否真正支付成功(见:notify.php)
  16. */
  17. $notify = new NativePay();
  18. $url1 = $notify->GetPrePayUrl("123456789");
  19. $goodsPrice = $_GET['goodsPrice'];
  20. $goodsName = $_GET['goodsName'];
  21. // print_r($goodsPrice);die;
  22. //模式二
  23. /**
  24. * 流程:
  25. * 1、调用统一下单,取得code_url,生成二维码
  26. * 2、用户扫描二维码,进行支付
  27. * 3、支付完成之后,微信服务器会通知支付成功
  28. * 4、在支付成功通知中需要查单确认是否真正支付成功(见:notify.php)
  29. */
  30. $input = new WxPayUnifiedOrder();
  31. $input->SetBody($goodsName);
  32. $input->SetAttach("今知商城");
  33. $num = WxPayConfig::MCHID.date("YmdHis");
  34. $input->SetOut_trade_no($num);
  35. $input->SetTotal_fee($goodsPrice*100);
  36. $input->SetTime_start(date("YmdHis"));
  37. $input->SetTime_expire(date("YmdHis", time() + 600));
  38. $input->SetGoods_tag($goodsName);
  39. $input->SetNotify_url("/payment/example/notify.php");
  40. $input->SetTrade_type("NATIVE");
  41. $input->SetProduct_id("123456789");
  42. $result = $notify->GetPayUrl($input);
  43. //echo "<pre>";
  44. //print_r($result);
  45. $url2 = $result["code_url"];
  46. ?>
  47. <html>
  48. <head>
  49. <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
  50. <meta name="viewport" content="width=device-width, initial-scale=1" />
  51. <title>微信支付样例</title>
  52. </head>
  53. <body>
  54. <div style="margin-left: 10px;color:#556B2F;font-size:30px;font-weight: bolder;">扫描支付模式二</div><br/>
  55. <img alt="||<?php echo $num?>||" src="qrcode.php?data=<?php echo urlencode($url2);?>" style="width:150px;height:150px;"/>
  56. <div id="myDiv"></div><div id="timer">0</div>
  57. <script>
  58. //设置每隔1000毫秒执行一次load() 方法
  59. var myIntval=setInterval(function(){load()},1000);
  60. function load(){
  61. document.getElementById("timer").innerHTML=parseInt(document.getElementById("timer").innerHTML)+1;
  62. var xmlhttp;
  63. if (window.XMLHttpRequest){
  64. // code for IE7+, Firefox, Chrome, Opera, Safari
  65. xmlhttp=new XMLHttpRequest();
  66. }else{
  67. // code for IE6, IE5
  68. xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  69. }
  70. xmlhttp.onreadystatechange=function(){
  71. if (xmlhttp.readyState==4 && xmlhttp.status==200){
  72. trade_state=xmlhttp.responseText;
  73. if(trade_state=='SUCCESS'){
  74. document.getElementById("myDiv").innerHTML='支付成功';
  75. //alert(transaction_id);
  76. //延迟3000毫秒执行tz() 方法
  77. clearInterval(myIntval);
  78. setTimeout("location.href='success.php'",3000);
  79. }else if(trade_state=='REFUND'){
  80. document.getElementById("myDiv").innerHTML='转入退款';
  81. clearInterval(myIntval);
  82. }else if(trade_state=='NOTPAY'){
  83. document.getElementById("myDiv").innerHTML='请扫码支付';
  84. }else if(trade_state=='CLOSED'){
  85. document.getElementById("myDiv").innerHTML='已关闭';
  86. clearInterval(myIntval);
  87. }else if(trade_state=='REVOKED'){
  88. document.getElementById("myDiv").innerHTML='已撤销';
  89. clearInterval(myIntval);
  90. }else if(trade_state=='USERPAYING'){
  91. document.getElementById("myDiv").innerHTML='用户支付中';
  92. }else if(trade_state=='PAYERROR'){
  93. document.getElementById("myDiv").innerHTML='支付失败';
  94. clearInterval(myIntval);
  95. }
  96. }
  97. }
  98. //orderquery.php 文件返回订单状态,通过订单状态确定支付状态
  99. xmlhttp.open("POST","orderquery.php",false);
  100. //下面这句话必须有
  101. //把标签/值对添加到要发送的头文件。
  102. xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
  103. xmlhttp.send("out_trade_no=<?php echo $num;?>");
  104. }
  105. </script>
  106. </body>
  • 微信支付demo 订单查询页面

  1. <?php
  2. header("Access-Control-Allow-Origin:*");
  3. ini_set('date.timezone','Asia/Shanghai');
  4. error_reporting(E_ERROR);
  5. require_once "../lib/WxPay.Api.php";
  6. require_once 'log.php';
  7. //初始化日志
  8. $logHandler= new CLogFileHandler("./logs/".date('Y-m-d').'.log');
  9. $log = Log::Init($logHandler, 15);
  10. function printf_info($data)
  11. {
  12. foreach($data as $key=>$value){
  13. echo "<font color='#f00;'>$key</font> : $value <br/>";
  14. }
  15. }
  16. if(isset($_REQUEST["transaction_id"]) && $_REQUEST["transaction_id"] != ""){
  17. $transaction_id = $_REQUEST["transaction_id"];
  18. $input = new WxPayOrderQuery();
  19. $input->SetTransaction_id($transaction_id);
  20. //printf_info(WxPayApi::orderQuery($input));
  21. $result=WxPayApi::orderQuery($input);
  22. echo $result['trade_state'];
  23. exit();
  24. }
  25. if(isset($_REQUEST["out_trade_no"]) && $_REQUEST["out_trade_no"] != ""){
  26. $out_trade_no = $_REQUEST["out_trade_no"];
  27. $input = new WxPayOrderQuery();
  28. $input->SetOut_trade_no($out_trade_no);
  29. //printf_info(WxPayApi::orderQuery($input));
  30. $result=WxPayApi::orderQuery($input);
  31. $status['code'] = $result['trade_state'];
  32. $status['openid'] = $result['openid'];
  33. $status['total_fee'] = $result['total_fee'];
  34. $status['transaction_id'] = $result['transaction_id'];
  35. $status['time'] = $result['time_end'];
  36. //print_r($result);
  37. print_r(json_encode($status));
  38. exit();
  39. }
  40. ?>
  1. 写的太差,请见谅;遇到问题了!

Wishes everybody to be happy everyday!
ok,bye!撸主要给客户继续写东西了!~否则明天揭不开锅了!

转自:https://segmentfault.com/a/1190000008606526

PHP PC端微信扫码支付【模式二】详细教程-附带源码(转)的更多相关文章

  1. ThinkPHP 整合微信支付 扫码支付 模式二 图文教程

    这篇文章主要介绍扫码支付场景二. 目前有两种模式,模式一比模式二稍微复杂点,至于模式一与模式二的具体内容,流程,微信开发文档都有详细介绍,这里就不多说废话,接下来赶紧上教程! [title]下载SDK ...

  2. 【微信开发】PC端 微信扫码支付成功之后自动跳转

    场景: PC端   微信扫码支付 结果: 支付成功 自动跳转 实现思路: 支付二维码页面,写ajax请求支付状态,请求到结果,无论成功还是失败,都跳转到相应的结果页面 具体实现方法: html部分: ...

  3. Java之微信支付(扫码支付模式二)案例实战

    摘要:最近的一个项目中涉及到了支付业务,其中用到了微信支付和支付宝支付,在做的过程中也遇到些问题,所以现在总结梳理一下,分享给有需要的人,也为自己以后回顾留个思路. 一:微信支付接入准备工作: 首先, ...

  4. 微信支付Native扫码支付模式二之CodeIgniter集成篇

    CI:3.0.5 微信支付API类库来自:https://github.com/zhangv/wechat-pay 请先看一眼官方场景及支付时序图:https://pay.weixin.qq.com/ ...

  5. 微信公众号 扫码支付 模式二 demo

    扫码支付 本文附有代码,在下方,如果不熟悉场景的可以看看下面的场景介绍 场景介绍 官网介绍地址:https://pay.weixin.qq.com/wiki/doc/api/native.php?ch ...

  6. PC 端微信扫码注册和登录

    一.前言 先声明一下,本文所注重点为实现思路,代码及数据库设计主要为了展现思路,如果对代码效率有着苛刻要求的项目切勿照搬. 相信做过微信开发的人授权这块都没少做过,但是一般来说我们更多的是为移动端的网 ...

  7. C# 微信扫码支付API (微信扫码支付模式二)

    一.SDK下载地址:https://pay.weixin.qq.com/wiki/doc/api/native.php?chapter=11_1,下载.NET C#版本: 二.微信相关设置:(微信扫码 ...

  8. JAVA微信扫码支付模式二功能实现完整例子

    概述 本例子实现微信扫码支付模式二的支付功能,应用场景是,web网站微信扫码支付.实现从点击付费按钮.到弹出二维码.到用户用手机微信扫码支付.到手机上用户付费成功.web网页再自动调整到支付成功后的页 ...

  9. .NET MVC结构框架下的微信扫码支付模式二 API接口开发测试

    直接上干货 ,我们的宗旨就是为人民服务.授人以鱼不如授人以渔.不吹毛求疵.不浮夸.不虚伪.不忽悠.一切都是为了社会共同进步,繁荣昌盛,小程序猿.大程序猿.老程序猿还是嫩程序猿,希望这个社会不要太急功近 ...

随机推荐

  1. Nginx的alias的用法及与root的区别

    以前只知道Nginx的location块中的root用法,用起来总是感觉满足不了自己的一些想法.然后终于发现了alias这个东西. 先看toot的用法 location /request_path/i ...

  2. java.lang.UnsupportedClassVersionError: xxx/xxxClass : Unsupported major.minor version 51.0【转】

    以下小段参考自overflow: Unsupported major.minor version 52.0 [duplicate] 或csdn也有提及 : http://blog.csdn.net/p ...

  3. docker入门(三)

    docker容器IP"暴露"到外网(宿主机外) 首先将docker容器IP固定 Docker自身的4种网络工作方式,简略说明下: host模式,使用--net=host指定. co ...

  4. oracle乱码记录

    plsql中显示正常,查询到的结果乱码 1.获得服务端编码 select * from nls_database_parameters where parameter ='NLS_CHARACTERS ...

  5. XQuartz简介

    这是一个类似于中转的软件,比如现在在Mac上,YY语音还没有官方版的,但其实在Mac上,有了XQuartz就可以实现运行YY了,下载这个从Windows上移植过来的软件,然后打开的时候,Mac会提醒你 ...

  6. PreparedStatement 基于mysql数据库做分页查询和统计查询

    分页查询: 统计查询:

  7. C++读写TXT文件中的string或者int型数据以及string流的用法

    对文件的读写操作是我们在做项目时经常用到的,在网上看了很多博客,结合自身的项目经验总结了一下,因此写了这篇博客,有些地方可能直接从别的博客中复制过来,但是都会注明出处. 一.文件的输入输出 fstre ...

  8. 二、Linear Regression 练习(转载)

    转载链接:http://www.cnblogs.com/tornadomeet/archive/2013/03/15/2961660.html 前言 本文是多元线性回归的练习,这里练习的是最简单的二元 ...

  9. freeRTOS中文实用教程3--中断管理之计数信号量

    1.前言 在中断不频繁的系统中,使用二值信号量没有问题,但是中断频繁发生时,则会有中断丢失的问题. 因为中断发生时延迟任务执行,延迟任务执行的过程中,如果又来了两次中断,则只会处理第一次,第二次将会丢 ...

  10. Ubuntu 16.04配置国内高速apt-get更新源【转】

    转自:https://blog.csdn.net/twang0x80/article/details/79782753 Ubuntu 16.04下载软件速度有点慢,因为默认的是从国外下载软件,那就更换 ...