H5微信外支付(移动端浏览器)

简介: H5微信外支付(移动端浏览器)

H5微信外支付(移动端浏览器)

​业务场景介绍:

H5移动端浏览器微信支付 >>>微信外支付(开发文档
在这里插入图片描述

订单生成逻辑:前端根据商品信息配合后端调用接口,后端返回跳转URL, 前端判断浏览器类型,是微信外浏览器则直接跳转打开,再根据提示打开微信,拉微信支付

开发前准备:

开通商户接入微信支付,配置相关信息(详见开发文档)

提交订单,跳转拉起微信客户端支付

前端根据商品信息配合后端调用接口,后端返回跳转URL, 前端判断浏览器类型,然后跳转,这里注意也就是开发文档的-->开发指引里面的3.2.2. 【客户端】微信外部的浏览器拉起微信支付中间页
,这里根据实际情况进行处理,有个redirect_url参数,这个是拼接在服务端返回的url地址后面而且必须通过encodeURIComponent()编码才行,如果拼接这个参数就是最后会跳转到这个页面,如果不拼接则跳到支付发起页。

如果拼接的话可以这样处理,

// 构造支付 URL
function constructPaymentUrl(webUrl, redirectUrl) {
   
    // 验证输入参数
    if (!webUrl || !redirectUrl) {
   
        console.error('Missing required parameters: webUrl or redirectUrl');
        return null;
    }
    // 对 redirectUrl 进行编码
    const encodedRedirectUrl = encodeURIComponent(redirectUrl);
    // 构造最终的支付 URL
    const paymentUrl = `${
     webUrl}&redirect_url=${
     encodedRedirectUrl}`;
    return paymentUrl;
}

// 示例调用
const body = {
   
    webUrl: 'https://example.com/payment?'
};
const redirectUrl = 'https://example.com/redirect';
const paymentUrl = constructPaymentUrl(body.webUrl, redirectUrl);
if (paymentUrl) {
   
    // 在微信内打开支付页面
    if (isWeChatBrowser()) {
   
        window.location.href = paymentUrl;
    } else {
   
        console.log('Not in WeChat browser, using fallback method.');
        // 使用备选方法打开支付页面
        window.open(paymentUrl, '_self');
    }
}

// 判断是否在微信浏览器内
function isWeChatBrowser() {
   
    return /MicroMessenger/i.test(navigator.userAgent);
}

判断浏览器以实际为准,需要注意:uc浏览器安卓和ios有点不一样,判断设备类型的时候需要注意,我遇到的是这样的情况,安卓可以正常打开但是ios不能,发现手机上打开设备类型也显示是windows,可以单独处理判断

const isUCBrowser = /UCBrowser/i.test(navigator.userAgent);
const isIosUCBrowser = /Windows; U;/i.test(navigator.userAgent)

if (isUCBrowser || isIosUCBrowser ) {
   
    window.location.href = paymentUrl
}

请添加图片描述

在这里插入图片描述

这种情况应该是哪里配置有问题,配合后端自行检查
请添加图片描述

支付结果页

由于是浏览器跳转的链接,最终无论支付还是取消支付返回浏览器都会跳转到发起页或者重定向页。但是不知道状态,只能通过通过用户去触发,浏览器返回到前面提交支付发起页,或者就是成功之后重定向到目标页(比如我的订单页)也可以是单独的页,给添加个跳转中间页给个按钮已付款(点击查看订单状态然后在跳转)和重新提交(返回到支付前的页面),再或者就是比如文档那样直接给个弹框,让用户去操作都行,(可以给弹框,给中间页,然后触发跳转)总之具体根据实际情况处理

博客链接:https://blog.csdn.net/m0_67708785/article/details/142918942

目录
相关文章
|
1月前
|
API 开发者
微信native支付对接案例详解
本文详细介绍了微信Native支付的对接流程,包括效果展示、产品介绍、接入前准备、开发指引、API列表、支付通知等,并强调了只有通过微信认证的服务号才能对接微信支付。每年需支付300元认证费用。
61 3
|
2月前
|
移动开发 小程序
仿青藤之恋社交交友软件系统源码 即时通讯 聊天 微信小程序 App H5三端通用
仿青藤之恋社交交友软件系统源码 即时通讯 聊天 微信小程序 App H5三端通用
91 3
|
3月前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
478 3
|
3月前
|
移动开发 安全 API
微信H5支付--微信JS-SDK支付--点金计划
本文详细介绍了微信H5支付和JS-SDK支付的原理、配置和开发流程,涵盖了H5支付在移动端浏览器外唤起微信支付的细节,以及JS-SDK支付在微信内置浏览器中完成支付的相关注意事项。文章还针对微信支付常见问题,提供了解决方案和代码示例。最后,文章深入解析了微信支付点金计划,包括商家小票的自定义开发、API接口以及支付成功后的页面展示逻辑,为开发者提供了完整的开发参考。
183 0
微信H5支付--微信JS-SDK支付--点金计划
|
3月前
|
移动开发 小程序 数据可视化
一招学会DIY官网可视化设计支持导出微擎、UNIAPP、H5、微信小程序源码
一招学会DIY官网可视化设计支持导出微擎、UNIAPP、H5、微信小程序源码
62 2
|
5月前
|
移动开发 前端开发 JavaScript
|
3月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
874 7
|
3月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
871 1
|
3月前
|
小程序 前端开发 测试技术
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
220 7
ly~
|
4月前
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
100 6