zoukankan      html  css  js  c++  java
  • uni-app开发经验分享八: 实现微信APP支付的全过程详解

    准备工作

    1. 申请了商户号,拿到了API秘钥。这个需要微信开发平台,相关的工作大家百度。
    2. 后面代码里用到的appid和秘钥之类需要实现申请号。
    3. 在uni-app manifest.json 配置sdk支付权限

    前端代码

    1. onload阶段获取了可用支付列表,这里我们只用到了微信支付。
    2. requestPayment  

              a. getOrderInfo 获取到订单信息,主要是prepayid,对应统一下单api的返回值。

              b. uni.requestPayment发起支付,效果就是弹出微信支付框输入密码支付。第一个参数是“wxpay”,第二个参数就是OrderInfo.

    前端代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    <template>
        <view>
            <page-head :title="title"></page-head>
            <view class="uni-padding-wrap">
                <view style="background:#FFF; padding:50upx 0;">
                    <view class="uni-hello-text uni-center">支付金额</text></view>
                    <view class="uni-h1 uni-center uni-common-mt">
                        <text class="rmbLogo">¥</text>
                        <input class="price" type="digit" :value="price" maxlength="4" @input="priceChange" />
                    </view>
                </view>
                <view class="uni-btn-v uni-common-mt">
                    <!-- #ifdef APP-PLUS -->
                    <template v-if="providerList.length > 0">
                        <button v-for="(item,index) in providerList" :key="index" @click="requestPayment(item,index)"
                            :loading="item.loading">{{item.name}}支付</button>
                    </template>
                    <!-- #endif -->
                </view>
            </view>
        </view>
        </view>
    </template>
    <script>
        export default {
            data() {
                return {
                    title: 'request-payment',
                    loading: false,
                    price: 1,
                    providerList: []
                }
            },
            onLoad: function() {
                // #ifdef APP-PLUS
                uni.getProvider({
                    service: "payment",
                    success: (e) => {
                        console.log("payment success:" + JSON.stringify(e));
                        let providerList = [];
                        e.provider.map((value) => {
                            switch (value) {
                                case 'alipay':
                                    providerList.push({
                                        name: '支付宝',
                                        id: value,
                                        loading: false
                                    });
                                    break;
                                case 'wxpay':
                                    providerList.push({
                                        name: '微信',
                                        id: value,
                                        loading: false
                                    });
                                    break;
                                default:
                                    break;
                            }
                        })
                        this.providerList = providerList;
                    },
                    fail: (e) => {
                        console.log("获取支付通道失败:", e);
                    }
                });
                // #endif
            },
            methods: {
                async requestPayment(e, index) {
                    this.providerList[index].loading = true;
                    let orderInfo = await this.getOrderInfo(e.id);
                    console.log("得到订单信息", orderInfo);
                    if (orderInfo.statusCode !== 200) {
                        console.log("获得订单信息失败", orderInfo);
                        uni.showModal({
                            content"获得订单信息失败",
                            showCancel: false
                        })
                        return;
                    }
                    uni.requestPayment({
                        provider: e.id,
                        orderInfo: orderInfo.data.data,
                        success: (e) => {
                            console.log("success", e);
                            uni.showToast({
                                title: "感谢您的赞助!"
                            })
                        },
                        fail: (e) => {
                            console.log("fail", e);
                            uni.showModal({
                                content"支付失败,原因为: " + e.errMsg,
                                showCancel: false
                            })
                        },
                        complete: () => {
                            this.providerList[index].loading = false;
                        }
                    })
                },
                getOrderInfo(e) {
                    let appid = "";
                    // #ifdef APP-PLUS
                    appid = plus.runtime.appid;
                    // #endif
                    let url 'http://10.10.60.200:8070/sc-admin/sales/wx/prepay/?brokerId=shba01';
                    return new Promise((res) => {
                        uni.request({
                            url: url,
                            success: (result) => {
                                res(result);
                            },
                            fail: (e) => {
                                res(e);
                            }
                        })
                    })
                },
                priceChange(e) {
                    console.log(e.detail.value)
                    this.price = e.detail.value;
                }
            }
        }
    </script>
     
    <style>
        .rmbLogo {
            font-size40upx;
        }
     
        button {
            background-color#007aff;
            color#ffffff;
        }
     
        .uni-h1.uni-center {
            display: flex;
            flex-direction: row;
            justify-contentcenter;
            align-items: flex-end;
        }
     
        .price {
            border-bottom1px solid #eee;
            width200upx;
            height80upx;
            padding-bottom4upx;
        }
     
        .ipaPayBtn {
            margin-top30upx;
        }
    </style>
  • 相关阅读:
    ABI与ARM,X86的概念
    数据库升级,如何操作
    shell脚本
    数据库设计范式
    jQuery基础教程
    git clone 失败 fatal: early EOF fatal: the remote end hung up unexpectedly fatal: index-pack failed
    windowserver中PowerShell禁止脚本执行的解决方法
    移动端延迟300ms的原因以及解决方案
    将伪数组转为真正的数组
    cnpm安装时候出现“Unexpected end of JSON input“的解决办法
  • 原文地址:https://www.cnblogs.com/HelloLc/p/14186995.html
Copyright © 2011-2022 走看看