最近去超市看到好多商户一个二维码同时支持支付宝、微信、QQ扫描付款,所以回来自己上网研究了一下。整理了一个现成的源码,有需要的朋友可以下载自己研究下。

主要参考了芝麻二维码。无论是支付宝还是微信的收款码,其本质上是一个包含了收款链接的二维码。所以我们的思路是:检测如果是支付宝浏览页面,就给出支付宝的付款链接、如果是微信,就给出微信链接……

那么问题来了,如何进行判定呢?

很好办,根据 UA 就能进行判定了!不懂什么是 UA?请参照(mkblog.cn) 浏览器野史 – UserAgent列传 这篇博文。

这部分的代码如下:

  1. if(navigator.userAgent.match(/Alipay/i)) {
  2. // 支付宝
  3. } else if(navigator.userAgent.match(/MicroMessenger\//i)) {
  4. // 微信
  5. } else if(navigator.userAgent.match(/QQ\//i)) {
  6. // QQ
  7. } else {
  8. // 其它
  9. }

理论上来说,进行判定后直接给跳转到对应的收款页面就行了,然而实际测试发现在QQ和微信中并不能直接调用付款功能,只有支付宝能直接进行付款。

这里就只能用一个折中的办法:如果是QQ或微信扫的码,就再放出一个二维码的界面,让用户通过长按识别二维码进入支付流程。

最终完成的效果如下:


你可以用 QQ 或是微信或是支付宝中的任意一个扫描这个二维码进行测试(当然如果打赏一下一斗米就再好不过了,手打偷笑…… 
 )

成品源码下载(单文件纯 html 实现,需上传至网站空间使用):

链接: https://pan.baidu.com/s/1o8JZ3Hg 密码: jmu5



注:

1.请将代码中第 19、22、25行中的收款链接改为自己的。

2.代码中第 108、117、126行中的文字可以自己修改成喜欢的。


请用专门的 Html 编辑器(如 sublime/notepad++)进行编辑,切勿直接用记事本编辑,否则可能出现中文乱码!

知识拓展:

以下以微信为例,QQ、支付宝的获取方法类似。

获取到各自的收款二维码截图。

用二维码识别工具(如 https://cli.im/deqr/) 上传二维码图片并获取到二维码中的收款链接。(不知道为什么我操作过程中有些识别不出来,备用方法https://www.hotapp.cn/jiema)

将获取到的收款链接粘贴并替换源码中的链接即可。


  1. // 在以下双引号中粘贴QQ钱包收款链接
  2. qqUrl: "https://i.qianbao.qq.com/wallet/sqrcode.htm?m=tenpay&a=1&u=1070238&ac=123AA8FA99EAEECBA53D8A29BF8B06963AEA141B073F9DD9DF683C03991BFEC9&n=?????&f=wallet",
  3. // 在以下双引号中粘贴微信收款链接
  4. wechatUrl: "https://wx.tenpay.com/f2f?t=AQAAABjEwaSRqT0fh0siYok3d1o%3D",
  5. // 在以下双引号中粘贴支付宝收款链接
  6. aliUrl: "HTTPS://QR.ALIPAY.COM/FKX02258IEDCF4CBEYRR82",


本文由--张嘉瑞乐园--整理,转载请注明本文标题和链接:《万能收钱码-多合一收款二维码原理及源码-支持支付宝、微信、QQ》

万能收钱码-多合一收款二维码原理及源码-支持支付宝、微信、QQ相关推荐

  1. spring源码分析第五天------springAOP核心原理及源码分析

    spring源码分析第五天------springAOP核心原理及源码分析 1. 面向切面编程.可以通过预 编译方式和运行期动态代理实现在不修改源代码的情况下给程序动态统一添加功能的一种技术 切面(A ...

  2. spring源码分析第四天------springmvc核心原理及源码分析

    spring源码分析第四天------springmvc核心原理及源码分析 1.基础知识普及 2. SpringMVC请求流程 3.SpringMVC代码流程 4.springMVC源码分析 4.1 ...

  3. 好用的在线二维码生成器网站PHP源码

    简介: 上传源码以后了,打开域名即可使用,源码仅供参考学习,严禁商业用途! 网盘下载地址: http://kekewangLuo.cc/ECmOiWH9R7z0 图片:

  4. 二、yolov5原理与源码学习

    提示:本专栏文章仅仅是个人学习记录过程,如有错误,欢迎评论! 文章目录 前言 一.detect.py的学习 1. 目录的创建过程 2. GPU的设置过程 3. 数据的加载过程 4. 后处理NMS过程 ...

  5. git 拉取 未能顺利结束 (退出码 1)_小白的 asyncio :原理、源码 到实现(1)

    去年的这个时候吧,我开始找工作,招聘启事上说,需要了解 asyncio. 我回去翻了翻书,orz····· 今年,在一次内部技术分享会上,我要分享的内容涉及到一些 python 协程,我又去看 asy ...

  6. 带你读源码:四大视角多维走读区块链源码

    作者 | 李辉忠 来源 | FISCO BCOS开源社区 封图 | CSDN下载自视觉中国 区块链作为「新基建」的重要组成部分,越来越受技术爱好者关注.区块链极客信奉"code is law ...

  7. 二维弹性波FWI源码和可执行程序

    无奈此platform涨分太快,贴[链接]自行下载吧! 链--接:https://pan.baidu.com/s/17tMagM8byhXPlMJbmeJLkA  提--取--码:jv15 订正: 由 ...

  8. Pytorch二维卷积 conv2d 使用/源码/手写实现conv2d/手写向量内积实现conv2d/转置卷积实现——学习笔记

    这里是一份学习笔记- 学习视频点这里

  9. android悬浮窗、收款二维码、相机处理、事件通知库、NFC读取等源码

    Android精选源码 一个漂亮而强大的自定义view SeekBar 适用于Android的简单NFC读取源码 安卓任意界面悬浮窗实现源码 android实现收款二维码保存代码 RxBus 一个简易 ...

  10. bytebuddy实现原理分析 源码分析 (二)

    bytebuddy实现原理分析 &源码分析 四.字节码的操作(implementation ) pkg 4.1 bytecode :pkg 4.1.1 StackManipulation :c ...

最新文章

  1. extmail电子邮件系统
  2. ORA-25153: Temporary Tablespace is Empty
  3. 知名大学硕士生被通报,这件事千万别做!
  4. 混淆矩阵与精确度、召回率、F1 Score
  5. solr mysql 速度_提高solr的搜索速度
  6. pcb设计单点接地示意图_EMC设计之接地、PCB布局布线、屏蔽设计
  7. netlogon启动后停止_优雅停止 SpringBoot 服务,拒绝 kill 9 暴力停止!
  8. 数据挖掘:Bloom filter
  9. 【Excel2019(十五):条件格式与公式】【使用简单的条件格式+定义多重条件的条件格式+使用公式定义条件格式】
  10. Android进程间通信系列-----------进程间的数据传递载体Parcel
  11. Nginx Passenger 性能调优
  12. 完美解决Win10 X64非原装版系统打不开CHM文件
  13. 加州大学圣克鲁兹分校计算机科学,加州大学圣克鲁兹分校专业设置详细介绍!...
  14. 实战教程!利用Python获取数据,并在地图上批量标注
  15. XMind: ZEN 快捷键超强盘点
  16. WebAssembly js性能对比
  17. [Offer收割机]编程练习赛1
  18. 使用scrapy爬取斗鱼直播间信息
  19. 苹果6访问限制密码4位_大连华讯投资股份有限公司:破解6位密码只需4秒,大写的尴尬!...
  20. 短语动词(Phrasal Verb)

热门文章

  1. puk码怎么查询_手机PUK码怎么查询?使用PUK码解锁手机电话SIM/USIM卡的教程
  2. PLC-Recorder仿真功能说明
  3. java随机生成6位流水号,Java生成随机流水号
  4. CAN总线协议学习笔记
  5. SecureCRT 终端仿真程序 v7.0.0.326 中文绿色便携破解版
  6. Coablt strike官方教程中文版
  7. ZYNQ平台Linux4.6内核蓝牙音频
  8. 超市管理系统数据库设计
  9. 盘点丨12款数据库建模工具特点,总有一款适合你!
  10. Mugeda(木疙瘩)H5案例课—什么,才是福-岑远科-专题视频课程