微信支付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

相关文章

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络

Android实现悬浮按钮功能

《Android实现悬浮按钮功能》在很多场景中,我们希望在应用或系统任意界面上都能看到一个小的“悬浮按钮”(FloatingButton),用来快速启动工具、展示未读信息或快捷操作,所以本文给大家介绍... 目录一、项目概述二、相关技术知识三、实现思路四、整合代码4.1 Java 代码(MainActivi

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32