微信内置H5支付

news/2024/7/3 21:43:36/文章来源:https://www.cnblogs.com/smileZAZ/p/18275493

🧑‍💻 写在开头

点赞 + 收藏 === 学会🤣🤣🤣

场景是用户通过微信扫app内的收款码,跳到一个h5页面。然后完成支付。

代码实现的整体流程:

使用微信扫码,码是app内生成的,码的内容是一个h5页面链接,扫码完成后跳转到自定义的h5支付界面。

扫码进入后,将页面展示所需要的参数进行缓存起来,存到本地。 然后需要微信静默授权。

  1. 微信静默授权的流程: 配置appid、redirect_uri等参数,从项目页面跳转到微信授权页面:https://open.weixin.qq.com/connect/oauth2/authorize 详细参考[ 微信官方文档]open.weixin.qq.com/connect/oau…

参数说明

// 示例
let ua = window.navigator.userAgent.toLowerCase();
if (ua.match(/MicroMessenger/i) == 'micromessenger') {// 回调地址:域名加页面路径let hdurl = encodeURIComponent('https://.../#/page_wallet');let appId = '申请项目的appid';window.location.href = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appId}&redirect_uri=${hdurl}&response_type=code&scope=snsapi_base#wechat_redirect`;
}

  

  1. 当授权后,会自动跳转到配置回调页面,也就是配置的‘redirect_uri’ 相当携带这code,重新打开了项目
  2. 然后解析url中的code,将code取出,支付的时候将code传给后端。

点击支付的时候,请求接口,使用微信浏览器内置对象WeixinJSBridge调起微信支付,使用方法如下所示,data就是由后端返回的数据。

function onBridgeReady(data) {WeixinJSBridge.invoke("getBrandWCPayRequest",{// 公众号名称,由商户传入appId: data.appId,// 时间戳,自1970年以来的秒数timeStamp: data.timeStamp,// 随机串nonceStr: data.nonceStr,package: data.package,// 微信签名方式:signType: "MD5",// 微信签名paySign: data.paySign,},function (res) {if (res.err_msg == "get_brand_wcpay_request:ok") {// 使用以上方式判断前端返回,微信团队郑重提示:// res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。}})}if (typeof WeixinJSBridge == "undefined") {if (document.addEventListener) {document.addEventListener("WeixinJSBridgeReady", onBridgeReady, false);} else if (document.attachEvent) {document.attachEvent("WeixinJSBridgeReady", onBridgeReady);document.attachEvent("onWeixinJSBridgeReady", onBridgeReady);}
} else {onBridgeReady();
}

在使用uniapp开发中使用的代码如下:

<template><view v-show="show">...内容省略<view @click="confirmPay">付款</view></view>
</template><script>// 支付接口import { payment_code } from '@/api/wallet';export default {data() {return {show: true, // 控制页面展示user: {}, // 页面信息form: { price: '', type: 0, code: null, receiver_id: null }, // 提交参数paydata: {} //返回的支付信息};},onLoad(e) {// 扫码后第一次进入该页面时if (e.id) {this.user = {name: e.name,id: e.id,};this.form.receiver_id = e.id;// 将信息存到本地uni.setStorageSync('userpay', this.user);}else{// 第二次进入(授权成功后,通过回调进入的页面)let data = uni.getStorageSync('userpay');this.user = {name: data.name,id: data.id,};this.form.price = data.price;this.form.receiver_id = data.id;let ua = window.navigator.userAgent.toLowerCase();//判断是不是微信if (ua.match(/MicroMessenger/i) == 'micromessenger') {// 第二次进来时,路径上已经携带了code,获取code。this.form.code = this.getUrlParam('code');}}// 去授权this.goAuthorization()},methods:{// 授权方法goAuthorization(){let ua = window.navigator.userAgent.toLowerCase();// //判断是不是微信if (ua.match(/MicroMessenger/i) == 'micromessenger') {// 判断是否已经获取了codeif (this.form.code == null || this.form.code === '') {// 如果还没有code,就跳转授权页面let hdurl = encodeURIComponent('https://.../#/page_wallet');let appId = '申请项目的appid';window.location.href = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appId}&redirect_uri=${hdurl}&response_type=code&scope=snsapi_base#wechat_redirect`;   }else{// 有code的话,就将页面内容显示出来this.show = true;}}}},// 点击支付后,调用confirm(e) {uni.showLoading({});uni.$u.http.post('支付接口',this.form).then(res=>{uni.hideLoading();// 将返回的data赋值this.paydata = res.data.data;let that = this;// 绑定事件if (typeof WeixinJSBridge == 'undefined') {if (document.addEventListener) {document.addEventListener('WeixinJSBridgeReady', that.wxonBridgeReady, false);} else if (document.attachEvent) {document.attachEvent('WeixinJSBridgeReady', that.wxonBridgeReady);document.attachEvent('onWeixinJSBridgeReady', that.wxonBridgeReady);}} else {this.wxonBridgeReady();}}).catch((err) => {// 如果接口调用失败了,将信息存起来,再走一遍授权。this.user.price = this.form.price;uni.setStorageSync('userpay', this.user);this.form.code = null;this.goAuthorization();});},// 微信支付wxonBridgeReady(){let that = this;WeixinJSBridge.invoke('getBrandWCPayRequest',{appId: that.paydata.appId,timeStamp: that.paydata.timeStamp,nonceStr: that.paydata.nonceStr,package: that.paydata.package,signType: that.paydata.signType,paySign: that.paydata.paySign},function (res) {// 如果取消了支付,就关闭当前h5页面,直接返回微信,也可以进行其他操作,通过res.err_msg来判断即可if (res.err_msg == 'get_brand_wcpay_request:cancel') {//关闭当前浏览器WeixinJSBridge.call('closeWindow');}// 这里是支付成功if (res.err_msg == 'get_brand_wcpay_request:ok') {// 使用以上方式判断前端返回,微信团队郑重提示://res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。}})},// 获取路径上参数的方法,用于获取codegetUrlParam(name) {const url = window.location.href;const queryString = url.split('?')[1];if (!queryString) return null;const params = queryString.split('&');for (const param of params) {const [key, value] = param.split('=');if (key === name) {return decodeURIComponent(value);}}return null;},} 
</script>

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

 


 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/733634.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《编译原理》阅读笔记:p25-p32

《编译原理》学习第 5 天,p25-p32总结,总计 8 页。 一、技术总结 1.lexical lexical这个单词后续会经常用到,所以首先要搞懂它的英文意思,不然看到中文的“词法,语法,文法”这三个词的时候就会懵了——lexical对应这三个里面的哪一个? (1)lexical: lexicon + al,加…

OOP七,八次作业总结

OOP四到六次作业总结 一.前言: 第七八次为家庭电路分析程序。 在第七次作业中,家庭电路系统,匹配类设计不当 在第八次作业中,我修改了输出类,并优化类的设计 二,设计与分析: 1.家居强电电路模拟程序-3(第七次作业) 在本次作业中,我对类的设计较为直白,输出类也没有…

findfont: Font family Times New Roman not found.

这是因为在python环境中的matplotlib文件夹下没有这个字体的文件。 对于windows系统,请参考:https://blog.csdn.net/qq_49323609/article/details/139026798 Macos系统:先打开软件:找到字体的路径然后模仿以上https://blog.csdn.net/qq_49323609/article/details/139026798…

模拟集成电路设计系列博客——8.2.1 环形振荡器

8.2.1 环形振荡器 在这一章节,我们将介绍振荡器的基本概念。环路振荡器可以分成若干种,但两种主要的分类依据是直接产生正弦信号还是产生方波(或者三角波)信号输出。正弦波输出振荡器常被用于一些频率选择或者反馈电路的调谐电路,而方波输出振荡器常被用于一个非线性反馈电…

分类器

网络模型分为特征提取器,包括一系列卷积层。池化层、激活函数; 分类器则是后面的全连接层; 对于全连接层直接输出的值为logits;logits也叫做模型输出的对数几率,$n_j$ 通常表示为模型对于第 j 类的输出值,也就是在进行Softmax函数转换之前的原始logits

Graph Neural Networks based Log Anomaly Detection and Explanation论文阅读笔记

1.介绍 现代高科技系统,如云服务器或高性能计算机,通常由大量的组件组成。随着时间的推移,这些系统变得越来越复杂,使得手动系统操作和维护变得困难甚至不可行[17]。因此,自动化系统操作和维护是非常可取的。为了实现这一点,系统日志被普遍用于记录系统状态和重要事件。通…

Miniconda安装使用说明

Anaconda这安装包体积真是劝退我了https://docs.anaconda.com/miniconda/miniconda是最小的conda安装环境,只有conda+python+pip+zlib和一些其他常用的包,体格不到100Mb,非常迷你。 Miniconda 使用教程 创建和管理环境 Conda 允许用户创建隔离的环境,以避免不同项目之间的依…

m基于GA遗传优化的高斯白噪声信道SNR估计算法matlab仿真

1.算法仿真效果 matlab2022a仿真结果如下:2.算法涉及理论知识概要基于遗传算法(Genetic Algorithm, GA)的高斯白噪声信道(Additive White Gaussian Noise, AWGN)信噪比(Signal-to-Noise Ratio, SNR)估计方法是一种利用生物进化原理进行全局优化的技术,旨在寻找最优解,…

重生之我在男航学Java-3(完结)

一、前言家居强电电路模拟程序-3 考查内容:类的设计(适应迭代以及合理的类间关系的设计),正则表达式的应用(如何正确解析输入),java中集合框架的熟悉与使用并且选择合理的集合框架(存储数据并且方便数据的增删改查) 新增内容:互斥开关,落地窗帘 本次PTA由于自身的原…

嵌入式计算和视觉加速的开放标准

嵌入式计算和视觉加速的开放标准 https://www.khronos.org/assets/uploads/developers/presentations/Khronos_Embedded_Compute_and_Vision_Overview_Jun24.pdf Khronos将软件连接到硅 开放、免版税的互操作性标准,以利用GPU、XR和多处理器硬件的力量3D图形、增强和虚拟现实、…

第三次Blog作业

题目集6-7的总结性Blog 一、前言 题目集总结 第六次题目集 知识点:控制理论、电路设计、设备工作原理 题量:中等 难度:中等偏上控制设备部分涉及对开关、分档调速器、连续调速器三种设备的理解和操作。需要理解开关的两种状态,分档调速器的档位变化以及连续调速器的连续调节…

第三次blog

第三次blog感悟 随着知识越学越多,任务也越来越繁重,难度也是与日俱增,也许是时间花得还不够也不够认真导致最近的一些pta作业都完成得差强人意,我认为java的学习最重要的是写作业的认真、严谨的逻辑以及大把的时间。nchu-software-oop-2024-上-6 本次作业题目大致内容 1、…

第三次PTA作业总结

一.第七和第八次PTA作业总结 1.第七次PTA作业的分析 (1).设计思路: 设计电路设备类(如ControlDevice, AdjustableDevice, ExclusiveSwitch)和受控设备类(Light, Fan, Curtain)来封装设备的属性和行为。 电路类(SequentialCircuit, ParallelCircuit)用于表示电路结构,…

在WPF中使用着色器

概念类比范畴 CPU GPU二进制文件 .exe .cso / .ps二进制指令 机器码 CSO(shader指令)助记符 汇编 SL高级语言 C# HLSL高级语言文件 .cs .hlsl / .fx高级语言编译器 csc.exe fxc.exeAPI .NET API DirectX API运行时环境 CLR DirectX调试工具 Visual Studio Debugger RenderDoc着…

OOP第三次博客作业

目录前言:设计与分析:opp-7-家居强电电路模拟程序-2opp-8-家居强电电路模拟程序-2踩坑心得:opp-5-家居强电电路模拟程序-3踩坑和心得:opp-5-家居强电电路模拟程序-4踩坑和心得:总结: 前言: oop-7相比与oop-6仅增加了两个电子元件,一个互斥开关,一个受控窗帘,除了优化…

《DNK210使用指南 -CanMV版 V1.0》第五章 编译CanMV固件

第五章 编译CanMV固件 1)实验平台:正点原子DNK210开发板 2) 章节摘自【正点原子】DNK210使用指南 - CanMV版 V1.0 3)购买链接:https://detail.tmall.com/item.htm?&id=782801398750 4)全套实验源码+手册+视频下载地址:http://www.openedv.com/docs/boards/k210/ATK-…

第三次PTA总结

前言 本阶段面向对象程序设计进行了两次PTA训练,两次都是关于电路设计的迭代。迭代次数越多难度越大,后期事情较多,作业和考试任务重、题目的难度也较大,所以没有拿到每次作业的满分,但是都根据题目的变化对自己的设计进行了一定的改变和优化。 知识点类的设计; 数组、链…

防火墙部署案例

通过引流方式实现防火墙旁挂部署并且实现安全防护功能案例 一、项目背景 1、客户有购买了一台某公司由于性能问题和服务器直连核心交换机原因,决定采取旁挂方式部署,但是又希望实现安全防护,因此决定通过引流方式(QOS的流量重定向)把需要防护的流量引到防火墙,防火墙做路…

6月29日

# 模板引用 $template=file_get_contents("1.php");之后可以引用page_title变量来替换html内容