uniapp 支付(vx、zfb、app、内嵌H5)

本人在做商城项目,需要多种支付方式,在这里记录一下,小白学习,勿喷

在项目路径下创建 common文件夹(随你起什么名),新建js文件  payment.js

/**
 * 支付相关方法
 */

/**
 * 微信小程序支付
 * @param {function} paymentParams 支付参数
 * @param {function} paySuccess 支付成功回调
 * @param {function} payFail 支付失败回调
 */
export function wechatMiniPay(paymentParams,paySuccess,payFail) {
    uni.requestPayment({
        provider: 'wxpay',//支付类型-固定值
        timeStamp: paymentParams.timeStamp,// 时间戳(单位:秒)
        nonceStr: paymentParams.nonceStr,// 随机字符串
        package: paymentParams.package,// 固定值
        signType: paymentParams.signType,//固定值
        paySign: paymentParams.paySign,//签名
        success(res) {
            paySuccess(res)
        },
        fail: function (err) {
            payFail(err)
        }
    })
}



/**
 * 微信App支付
 * @param {function} paymentParams 支付参数
 * @param {function} paySuccess 支付成功回调
 * @param {function} payFail 支付失败回调
 */
export function wechatAppPay(orderInfo,paySuccess,payFail) {
    uni.requestPayment({
        provider: 'wxpay',
        orderInfo:orderInfo,
        success(res) {
            paySuccess(res)
        },
        fail: function (err) {
            payFail(err)
        }
    })
}



/**
 * 手机浏览器h5支付
 * @param {Object} paymentParams
 * @param {Object} paySuccess
 * @param {Object} payFail
 */
export function mobileH5Pay(response,paySuccess,payFail) {
    location.href = response.gateway_url

}
/**
 * 微信内嵌h5支付
 * @param {Object} paymentParams
 * @param {Object} paySuccess
 * @param {Object} payFail
 */
export function wechatH5Pay(paymentParams,paySuccess,payFail) {
       WeixinJSBridge.invoke(
          'getBrandWCPayRequest', {
             "appId":paymentParams.appId,     //公众号名称,由商户传入
             "timeStamp":paymentParams.timeStamp,        //时间戳,自1970年以来的秒数
             "nonceStr":paymentParams.nonceStr, //随机串
             "package":paymentParams.package,
             "signType": paymentParams.signType,        //微信签名方式
             "paySign":paymentParams.paySign //微信签名
          },
          function(res){
            paySuccess(res)
            if(res.err_msg == "get_brand_wcpay_request:ok" ){

            }
       });
}

/**
 * 支付宝H5支付
 * 在
 * @param {Object} paymentParams
 * @param {Object} paySuccess
 * @param {Object} payFail
 */
export function aliPayH5(response,paySuccess,payFail) {
    let $formItems = ''

    if(response.form_items){
        response.form_items.forEach(item => {
          $formItems += `<input name="${item.item_name}" type="hidden" value='${item.item_value}' />`
        })
    }
    let $form = `<form action="${response.gateway_url}" method="post">${$formItems}</form>`
    document.getElementsByClassName('__pay_form__')[0].innerHTML = $form
    document.forms[0].submit()

}

export function aliPayApp(response,paySuccess,payFail) {
    uni.requestPayment({
        provider: 'alipay',
        orderInfo: response.gateway_url, //支付宝订单数据
        success: function (res) {
            paySuccess()
        },
        fail: function (err) {
            console.log('fail:' + JSON.stringify(err));
        }
    });
}

在需要调用支付的页面引入

import * as Payment from '@/common/payment.js'

Payment.wechatH5Pay(response, this.payCallback, this.payFail)

### 支付支付前后端集成实现方案 #### 一、支付支付流程概述 当用户通过应用发起支付请求时,前端需向后端发送支付参数。后端接收到这些参数后,调用支付宝提供的接口生成预订单并获取支付链接或二维码。最后,前端根据后端返回的数据引导用户完成支付操作[^1]。 #### 二、Android平台下的快速集成指南 对于希望初步了解支付宝SDK集成过程的开发者而言,在不具备正式签约条件的情况下,可以借助官方提供的沙箱环境来进行测试。具体来说,下载沙箱版本的钱包应用程序,并按照文档说明配置项目中的`alipaySdk-xxx.jar`文件以及相应的权限声明等设置项[^3]。 #### 三、PC端网页集成方式 针对桌面浏览器场景下接入支付宝付款功能的需求,应参照《电脑网站支付》API文档指引实施开发工作。此模式适用于商家希望通过其官方网站提供安全便捷的商品购买途径给顾客的情形[^4]。 #### 四、H5页面嵌入式解决方案 为了使移动Web应用能够顺利调起客户端内的Alipay APP来处理账单结算事宜,则可采用如下JavaScript代码片段创建隐藏表单元素并将服务器响应体中携带的实际POST数据注入其中;随后触发提交动作以打开目标URL地址[^5]: ```javascript const formElement = document.createElement("div"); formElement.style.display = "none"; formElement.innerHTML = res.payData; if (formElement.firstChild) { formElement.firstChild.target = "_blank"; document.body.appendChild(formElement); formElement.firstChild.submit(); document.body.removeChild(formElement); } ``` #### 五、安全性考量 在整个交互过程中务必重视信息安全保障措施的应用,比如对敏感信息加密传输、校验签名合法性等方面的工作不可忽视。此外,还需注意遵循各环节所涉及的技术规范与合规性要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值