MUI 支付案例(支付寶/微信)

首先說明一下,本文借鑑了多位博主的文章,因此會看到不少同樣的代碼。javascript

寫這篇博客主要目的是爲了便於後期查看(很差之處,敬請留言吐槽),案例經本人測試,是能夠使用的。css

先上效果圖html

前端HTML代碼: 前端

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8">
 5         <title>支付</title>
 6         <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
 7         <link rel="stylesheet" href="css/mui.min.css" />
 8         <link rel="stylesheet" href="css/pay.css" />
 9     </head>
10 
11     <body>
12         <hrader class="mui-bar mui-bar-nav">
13             <a class="mui-action-back mui-icon mui-icon-left-nav mui-pull-left"></a>
14             <h1 class="mui-title">第三方支付</h1>
15         </hrader>
16         <div class="mui-content">
17             支付金額:
18             <input id="jine" type="number" value="0.01" />19             <div class="top oauth-area" id="testLogin">
20                 <input type="button" id="wxpay" class="weixin pay" value="微信支付" />
21                 <input type="button" id="alipay" class="zhifubao pay" value="支付寶支付" />
22             </div>
23         </div>
24         <ul class="mui-table-view">
25             <li class="mui-table-view-cell"> 支付方式: <span id="channel"></span> </li>
26             <li class="mui-table-view-cell"> 訂單號: <span id="bill_no"></span> </li>
27             <li class="mui-table-view-cell"> 支付金額: <span id="total_fee"></span> </li>
28             <li class="mui-table-view-cell"> 支付狀態:<span id="status"></span> </li>
29             <textarea name="" id="status_msg" cols="20" rows="5"></textarea>
30         </ul>
31     </body>
32 </html>
33 <script type="text/javascript" src="js/mui.min.js"></script>
34 <script type="text/javascript" src="js/beecloud.js"></script>
35 <script>
36     mui.init({
37         swipeBack: true //啓用右滑關閉功能  
38     });
39     mui('.mui-content').on('tap', '.pay', function() { // 獲取 點擊效果微信仍是支付平臺
40         var channel_id = null;
41         switch(this.id) {
42             case 'alipay':
43                 channel_id = 'ALI_APP';
44                 break;
45             case 'wxpay':
46                 channel_id = 'WX_APP';
47                 break;
48             default:
49                 break;
50         }
51         beecloudPay(channel_id);
52         document.getElementById("channel").innerHTML = channel_id;
53         document.getElementById("total_fee").innerHTML = document.getElementById('jine').value;
54         document.getElementById("bill_no").innerHTML = beecloud.genBillNo();
55     })
56 
57     function beecloudPay(bcChannel) {
58         //因DCloud還沒有申請銀聯帳號,故支付寶、微信使用的是DCloud的appid,銀聯暫時使用BeeCloud的appid,開發者這裏無需判斷,直接寫一個appid便可;
59         var _appid = bcChannel == "UN_WEB" ? "c37d661d-7e61-49ea-96a5-68c34e83db3b" : "44f01a13-965f-4b27-ba9f-da678b47f3f5"
60         /*
61          * 構建支付參數
62          * app_id: BeeCloud控制檯上建立的APP的appid,必填 
63          * title: 訂單標題,32個字節,最長支持16個漢字;必填
64          * total_fee: 支付金額,以分爲單位,大於0的整數,必填
65          * bill_no: 訂單號,8~32位數字和/或字母組合,確保在商戶系統中惟一,必填
66          * optional: 擴展參數,能夠傳入任意數量的key/value對來補充對業務邏輯的需求;此參數會在webhook回調中返回; 選填
67          * bill_timeout: 訂單失效時間,必須爲非零正整數,單位爲秒,必須大於360。選填 
68          */
69         var payData = {
70             app_id: _appid,
71             channel: bcChannel,
72             title: "DCloud項目捐贈",
73             total_fee: document.getElementById('jine').value * 100,
74             bill_no: beecloud.genBillNo(),
75             optional: {
76                 'uerId': 'beecloud',
77                 'phone': '4006280728'
78             },
79             bill_timeout: 360,
80             return_url: "http://www.dcloud.io/demo/pay" //wap支付成功後的回跳地址
81         };
82         /*    發起支付
83          *  payData: 支付參數
84          *  cbsuccess: 支付成功回調
85          *  cberror: 支付失敗回調
86          */
87         beecloud.payReq(payData, function(result) {
88             document.getElementById("status").innerHTML = 'success';
89             document.getElementById("status").style.color = 'green'
90             document.getElementById("status_msg").innerHTML = "-------- 支付成功 --------" + "\n感謝您的支持,咱們會繼續努力完善產品";
91             console.log(result);
92         }, function(e) {
93             document.getElementById("status").innerHTML = 'failed';
94             document.getElementById("status").style.color = 'red'
95             document.getElementById("status_msg").innerHTML = "-------- 支付失敗 --------\n" + "錯誤碼:" + e.code + '\n' + e.message;
96         });
97     }
98 </script>
View Code

beecloud.jsjava

  1 var beecloud = {}; //定義一個beecloud對象
  2 var channels = null;
  3 var w = null;
  4 
  5 /**
  6  *  定義一個支付通道payReq 
  7  *  data 回調參數
  8  *  cbsuccess 成功回調返回的函數信息
  9  *  cberror   失敗返回的信息
 10  * */
 11 
 12 beecloud.payReq = function(data, cbsuccess, cberror) {
 13     doPay(data, cbsuccess, cberror);
 14 };
 15 // 定義一個隨機函數 對象的商品信息訂單號
 16 beecloud.genBillNo = function() {
 17     var d = new Date();
 18     var vYear = d.getFullYear();
 19     var vMon = d.getMonth() + 1;
 20     var vDay = d.getDate();
 21     var h = d.getHours();
 22     var m = d.getMinutes();
 23     var se = d.getSeconds();
 24     var ms = d.getMilliseconds();
 25     var rnadom = Math.floor(Math.random() * 100000000 + 10000000).toString();
 26     billno = "" + vYear + (vMon < 10 ? "0" + vMon : vMon) + (vDay < 10 ? "0" + vDay : vDay) + (h < 10 ? "0" + h : h) + (m < 10 ? "0" + m : m) + (se < 10 ? "0" + se : se) + ms;
 27     return billno + rnadom;
 28 };
 29 
 30 mui.plusReady(function() {
 31     //配置業務支持的支付通道,支付須要服務端支持,在BeeCloud上支持支付寶支付和微信支付;  
 32     var support_channel = ['alipay', 'wxpay'];
 33     plus.payment.getChannels(function(s) {
 34         channels = s; // 支付跳轉受權第三方成功回調信息
 35     }, function(e) {
 36         console.log("獲取支付渠道信權限失敗:" + e.message);
 37     });
 38 });
 39 // 
 40 function getRandomHost() {
 41     var hosts = ['https://apibj.beecloud.cn',
 42         'https://apihz.beecloud.cn',
 43         'https://apisz.beecloud.cn',
 44         'https://apiqd.beecloud.cn'
 45     ];
 46     return "" + hosts[parseInt(3 * Math.random())] + "/2/rest/app/bill";
 47 }
 48 
 49 /**
 50  * 獲取支付通道
 51  * 
 52  */
 53 function getPayChannel(bc_channel) {
 54     var dc_channel_id = '';
 55     switch(bc_channel) {
 56         case 'ALI_APP':
 57             dc_channel_id = 'alipay';
 58             break;
 59         case 'WX_APP':
 60             dc_channel_id = 'wxpay';
 61             break;
 62         default:
 63             break;
 64     }
 65 
 66     for(var i in channels) {
 67         if(channels[i].id == dc_channel_id) {
 68             return channels[i];
 69         }
 70     }
 71     return null;
 72 }
 73 /***
 74  *
 75  * 支付回調函數
 76  * 
 77  *
 78  */
 79 function doPay(payData, cbsuccess, cberror) {
 80     if(w) return;
 81 
 82     w = plus.nativeUI.showWaiting();
 83     mui.ajax(getRandomHost(), {
 84         data: JSON.stringify(payData),
 85         type: 'post',
 86         dataType: 'json',
 87         contentType: "application/json",
 88         success: function(data) {
 89             w.close();
 90             w = null;
 91             var paySrc = '';
 92 
 93             if(data.result_code == 0) {
 94                 var payChannel = getPayChannel(payData.channel);
 95 
 96                 if(payChannel) {
 97                     if(payChannel.id === 'alipay') {
 98                         paySrc = data.order_string;
 99                     } else if(payChannel.id === 'wxpay') {
100                         var statement = {};
101                         statement.appid = data.app_id;
102                         statement.noncestr = data.nonce_str;
103                         statement.package = data.package;
104                         statement.partnerid = data.partner_id;
105                         statement.prepayid = data.prepay_id;
106                         statement.timestamp = parseInt(data.timestamp);
107                         statement.sign = data.pay_sign;
108                         paySrc = JSON.stringify(statement);
109                     }
110                     //mui.toast("paySrc:" + paySrc);
111                     plus.payment.request(payChannel, paySrc, cbsuccess, cberror);
112                 } else if(payData.channel == 'UN_WEB') {
113                     //銀聯在線支付
114                     var web = plus.webview.create('', "beecloudPay");
115                     //注入JS,解決銀聯界面返回的問題
116                     web.setJsFile('_www/js/95516.js');
117                     web.addEventListener('loaded', function() {
118                         if(!web.isVisible()) {
119                             web.show();
120                         }
121                     });
122                     web.loadData(data.html);
123                 }
124             } else {
125                 var bcError = {};
126                 bcError.code = data.result_code;
127                 bcError.message = data.result_msg + ":" + data.err_detail;
128                 cberror(bcError);
129             }
130         },
131         error: function(xhr, errorType, error) {
132             w.close();
133             w = null;
134             var bcError = {};
135             bcError.code = -1;
136             bcError.message = errorType + ":" + xhr.responseText;;
137             cberror(bcError);
138         }
139     });
140 }
View Code

pay.cssweb

 1 .mui-content {
 2     text-align: center;
 3     margin-top: 40px;
 4     margin-bottom: 40px;
 5 }
 6 
 7 .top {
 8     margin-top: 40px;
 9 }
10 
11 .weixin {
12     width: 200px;
13     height: 50px;
14     background: url(img/icon-weixin.png) 10px center no-repeat;
15     background-size: 20%;
16     padding: 30px;
17     border-radius: 8px;
18     padding-left: 30px;
19     margin-bottom: 20px!important;
20 }
21 
22 .zhifubao {
23     width: 200px;
24     height: 50px;
25     background: url(img/alipay.jpg) 10px center no-repeat;
26     background-size: 20%;
27     padding-left: 30px;
28 }
29 
30 #jine {
31     -webkit-user-select: text;
32     text-align: right;
33     padding: 0 1em;
34     border: 0px;
35     border-bottom: 1px solid #ECB100;
36     border-radius: 0;
37     font-size: 16px;
38     width: 30%;
39     outline: none;
40     text-align: center;
41 }
View Code
相關文章
相關標籤/搜索