微信支付ios正常android不正常,单页(SPA)项目中微信支付在IOS和Android的坑 坑 坑!!...

2024-03-12 15:40

本文主要是介绍微信支付ios正常android不正常,单页(SPA)项目中微信支付在IOS和Android的坑 坑 坑!!...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

单页(SPA)项目中微信支付在IOS和Android不同表现

1.使用SPA做微信公众号开发,在做微信支付功能的时候, 前端技术选型用的vuejs+vue-router,vue-router使用hash模式 ,调起支付时 安卓手机支付正常,IOS手机提示当前url未注册。(此处安卓支付正常,排除了授权目录及各种微信公众号后台配置错误的问题)

808720383da3

2.经过各种调试,最终发现了ios和安卓手机在支付页的打印url是有差异的,查阅资料发现在ios和安卓下呼出微信支付的时候,微信支付判断当前路径的规则分别是:

IOS:Landing Page

安卓:Current Page

基本定义:

当前页面叫做“Current Page”;

当我们从微信别的地方点击链接打开微信浏览器时所在的页面、或者点击微信浏览器的刷新按钮时所刷新的页面,我们叫做“Landing Page”。

例如:我们点击链接进入页面A,然后依次浏览到B、C、D,那么Current Page就是D,而Landing Page是A,如果此时我们在D页面点击一下浏览器的刷新按钮,那么Landing Page就变成了D(以上均是在SPA应用的环境下,即以hash模式通过js更改浏览器路径,location.href跳转的不算)

这就意味着,在ios环境下,任何一个页面都有可能成为支付页面(因为我无法预知和控制用户在哪个页面点微信浏览器的刷新按钮,或是用户通过哪个连接从外部进入到系统)。

由此想到一个解决方案,就是进入到支付页面的时候使用href跳转的方式(或者在当前页reload一下),但会造成页面刷新,很影响用户体验

既然hash路由模式会有这么多不可控因素,是否可以考虑另一种路由方式呢?于是将项目的路由配置改成了history模式

808720383da3

试了一下,安卓和ios都成功调起了微信支付。大功告成....

突然想到,前面hash中,用户刷新会影响支付的调起,于是忐忑的点了一下页面的刷新。。。。

404

查阅vue官方发现,当我们设置了mode为history时,当前端发送路径给服务端时,服务端根本就不认识省去#的url,所以返回给我们404.也就是history模式下,当前路径并不真实存在,这个问题还是比较好解决的。

用nginx配置一下。

在nginx的配置文件中修改

方法一:

server {

listen      9010;

server_name  localhost;

location /{

root  F:/mxr/WebApp/mxr/unpackage/dist/build/h5/;

index  index.html index.htm;

if(!-e$request_filename) {

rewrite ^/(.*) /index.html last;

break;

}

}

}

方法二:

至此  history路由模式+后端nginx完美解决SPA微信支付问题

这篇关于微信支付ios正常android不正常,单页(SPA)项目中微信支付在IOS和Android的坑 坑 坑!!...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/801755

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

在ASP.NET项目中如何使用C#生成二维码

《在ASP.NET项目中如何使用C#生成二维码》二维码(QRCode)已广泛应用于网址分享,支付链接等场景,本文将以ASP.NET为示例,演示如何实现输入文本/URL,生成二维码,在线显示与下载的完整... 目录创建前端页面(Index.cshtml)后端二维码生成逻辑(Index.cshtml.cs)总结

Spring Boot项目如何使用外部application.yml配置文件启动JAR包

《SpringBoot项目如何使用外部application.yml配置文件启动JAR包》文章介绍了SpringBoot项目通过指定外部application.yml配置文件启动JAR包的方法,包括... 目录Spring Boot项目中使用外部application.yml配置文件启动JAR包一、基本原理

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Springboot项目登录校验功能实现

《Springboot项目登录校验功能实现》本文介绍了Web登录校验的重要性,对比了Cookie、Session和JWT三种会话技术,分析其优缺点,并讲解了过滤器与拦截器的统一拦截方案,推荐使用JWT... 目录引言一、登录校验的基本概念二、HTTP协议的无状态性三、会话跟android踪技术1. Cook