webview内嵌uniappH5支付

 ————————————————重要通知——————————————

Hello,本人的博客文章已更新至个人网站(www.jonexu.cn)

文章中有问题可以到网站联系博主,后续新的文章也将更新在个人网站

——————————————————————————————————

这玩意是真的到处是坑,app支付就不讲了,用官方uni.requirepayment能走完的,后续有时间可以稍稍整理点坑出来

主要讲uniapp h5支付,包括嵌套到webview(某糟心果)支付

h5支付接口啥的前端没什么关系,主要是后端的活,可以让你后端去看这两个文档

支付宝网站支付微信h5支付(微信确认已开通H5支付资格:微信商户平台——产品大全——H5支付(已开通))

特别注意:微信这里我讲的是外部浏览器支付,因为还有微信内部浏览器支付的写法,与本次讲的h5支付不同。

前端不要去研究怎么唤醒支付宝/微信,你只需要研究从后端拿到的form(支付宝)或者url(微信)时该做那些处理。

主讲是网上的各种坑,如何设置完成回调,微信支付完成回调到浏览器问题,支付宝回调在webview里打开新链接问题

微信h5支付:
后端写一个接口去访问微信的接口,微信会返回一段链接,直接回调给前端,前端处理代码如下

// #ifdef H5
this.$ajax.JPost(myApi,myArgument,(res)=>{//请求后台接口获取url
    //拼接自己定义的返回页面,注意一定要encode
    let myQuery="&redirect_url="+encodeURIComponent("www.公司域名.com/xxxx")
	window.location.href=res+myQuery;//跳转
});
// #endif

支付完成/取消回调
微信的回调是前端在后端返回url时自己做拼接,拼接一个叫redirect_url的query参数,配置的地址主域名得在微信商户平台配置H5白域名(微信商户平台——产品大全——开发配置——h5白域名)。

这里有个坑,可能刚配置的白域名微信后台还未刷新,导致唤醒微信是提示“商家存在未配置的参数”等错误。如确认配置一致后建议稍等个半天,别白瞎了宝贵生命,毕竟我被他坑的太阳公公出山时才躺下的,第二天莫名其妙就正常了。

在h5中以上也是ok的,但是ios webview中我微信的回调会直接打开Safari浏览器。Oh,No!
所以!我们需要了解一下UrlSchemes: uniappIOS urlSchemes文档.

作用是访问这个“地址”能唤醒app,就像你能唤醒微信支付宝一样,他们都给自己取了一个“UrlSchemes”

Ios中配置了之后(注意uniapp配置需打包后生效)在Safari中输入你的UrlSchemes+“://”成功唤醒你的app则配置成功,

有了这一出,我修改了上面微信唤醒逻辑,我打开自己的webview页面支付时告诉自己的h5page是webview访问,然后配置redirect_url时拼接自己app的UrlSchemes,让其支付回调的是app而非浏览器

注意这个UrlSchemes要让微信认,一样得配置h5白域名 ,我们配置的UrlSchemes就是白域名“www.公司域名.com”。

// #ifdef H5
this.$ajax.JPost(myApi,myArgument,(res)=>{//请求后台接口获取url
    //拼接自己定义的返回页面,注意一定要encode
    let myQuery="www.公司域名.com/参数xxx";//默认走h5回调
    if(this.isFromWebview){	
        myQuery="myappUrlSchemes://参数xxx"
    }
	window.location.href=res+"&redirect_url="+encodeURIComponent(myQuery);//跳转
});
// #endif

监听app被UrlSchemes唤醒

在app.vue中onLaunch写
// #ifdef APP-PLUS
	plus.globalEvent.addEventListener('newintent', (e)=>{
		var args= plus.runtime.arguments;  
		if(args){//值就是"myappUrlSchemes://参数xxx"
            let argArr=args.split("myappUrlSchemes://");
			uni.redirectTo({//关闭当前的webview,并跳转到app支付成功页面
				url:"/pages/public/payResult?"+argArr[1]
			})
		}
	
	}
});
// #endif


支付宝:
支付宝的h5支付也是后端写接口把我们系统申请的商户信息啥的去调用支付宝的接口。然后支付宝会返回一段form表单的html。
后端直接返回给前端,前端只需如下处理就可以唤醒支付宝app进行支付。

// #ifdef H5
this.$ajax.JPost(myApi,myArgument,(res)=>{//请求后台接口获取form

const div = document.createElement('div');
div.innerHTML = res;
document.body.appendChild(div);
//document.getElementsByName("return_url")[0].value//其实这里能抓到表单中的一些值,但是我想修改就失败了

//表单填入之后,调用表单的提交,以此来跳转到支付宝的h5收银台,它会去唤醒支付宝app
document.forms.alipaysubmit.submit();

//网上还流传这两种提交form方式,我是失败了,用上面那种是成功的
//document.forms['alipaysubmit'].alipaysubmit.submit();

});
// #endif

支付宝完成回调:

唤醒app后 ios需要手动切换回自己的app(这里有位老铁说可以改参自动回调,我拦截url没看到那个参数,所以就没强求了,毕竟官方说了ios h5不会回调。PS:url拦截往下看,后面要用的!)

主要讲解点:用户在支付宝h5收银台点击“已完成付款”或者左上角“X”的时触发的回调:

主要需要后端请求支付宝接口时需要给支付宝两个参,return_url(交易完成或取消返回地址)和biz_content中的quit_url(中途退出返回地址),我配置的都是一样的。这两参应该是由前端定义,前端想让支付宝收银台完成操作时跳到哪个页面得自己想好(PS:我的做法是让支付宝和微信都跳转到一个叫支付结果的页面,在这个页面能查询刚交易的结果)。

webview中:

以上流程在h5中是ok的,如果你的webview符合你的业务逻辑就不需要往下看了

我是用在app ios端用webview去访问,支付宝h5收银台完成回调时,会打开当前webview然后去访问我们配置的return_url中的地址,我这里就会出现webview中我在一开始跳转webview给的参数丢失情况,比如token。

为了与微信统一逻辑,我想让支付宝支付完成也跳转到app中的支付成功页面,而非继续在webview中游荡。所以我做了h5+联盟中提到的webview跳转url拦截,也就是对支付宝h5收银台的回调跳转做拦截,让其跳转到app中的支付成功页面。app中webview代码如下:

onReady() {
	// #ifdef APP-PLUS
	const currentWebview = this.$mp.page.$getAppWebview();
	var wv = currentWebview.children()[0];

    // wv.overrideUrlLoading({mode: 'allow',match: '.*alipay\.com/.*'},(e)=>{//允许阿里的地址跳转
	wv.overrideUrlLoading({mode: 'reject',match: '.*公司域名\.com.*'},(e)=>{//拦截我定义的阿里return_url地址,假设你定义的是“https://www.公司域名.com”,正则,不懂建议去学习下
		uni.redirectTo({//拦截到了就跳转到app中的支付成功页面
			url:"/pages/public/payResult?ptype=alipay&orderid=xxx"
		})
	});
	// #endif
},


 

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 18
    评论
随着互联网的发展,移动互联网的普及,手机APP已成为人们使用最多的移动终端产品之一。随着越来越多的APP应用的涌现,越来越多的APP需要内嵌H5页面WebView进行网页的展示和交互。WebView是一种可在应用程序中嵌入Web页面的控件,可以用来显示来自互联网上的Web页面。它可以实现在应用中展示网页或在线功能,解决一些本地应用无法实现的功能。下面,我们分别从用户、开发者两个方面来探讨APP内嵌H5页面WebView的优缺点。 一、用户方面: 优点: 1.节省时间:在APP中直接查看嵌入的网页,省去了用户手动打开浏览器输入网址的步骤; 2.良好的用户体验:页面加载速度相对较快,而且对主应用对内存占用少,不影响其他应用的使用; 3.方便分享:在WebView中打开的网页可以长按复制网址链接,方便分享给其它用户; 4.强大的交互能力:在APP中嵌入H5页面,拓展了应用的交互能力。 缺点: 1.便捷性带来的安全隐患:一些App会在内嵌H5页面中嵌入第三方广告,导致用户隐私泄露; 2.缺乏统一标准:因为浏览器的内核和引擎都是不同的,所以在不同的WebView中,同一网页的显示效果和交互体验可能会有差异。 二、开发者方面: 优点: 1.拓展应用功能:借助WebView内嵌H5页面,应用的功能可以得到极大的拓展; 2.代码复用:WebView可以实现HTML、CSS等内容的兼容,减轻了移动开发者负担; 3.节省开发成本:相对于开发单独的H5 APP内嵌方式更为灵活,可以适用于不同场景和需求。 缺点: 1.不支持多线程:WebView在JS调用本地方法的时候是在同一线程下执行的,如果WebView的内容较为复杂,可能会导致主线程卡顿; 2.性能问题:在内存管理、布局排版等方面还不如原生应用; 3.浏览器兼容性:WebView的内核并没有得到很好的统一,不同的WebView之间有兼容性问题,会导致页面显示和交互问题; 4.安全问题:WebView加载HTML页面时容易受到跨站脚本(XSS)和恶意代码注入等安全漏洞的攻击。为此,开发者应该加强前端页面安全防范,对浏览器缓存和Cookie进行管理并开启CSP(内容安全策略)。 综合来看,在APP内嵌H5页面WebView上,开发者需要在开发时注意安全方面的问题,同时还需要加强对WebView性能和兼容性的了解和优化。用户便捷性和良好的用户体验,也需要开发者在开发时重视。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值