QQ微信支付宝三合一收款码原理及代码实现

QQ微信支付宝三合一,只需要扫一个收款码就行呢?
这里涉及到一个知识点,则是User-Agent,大厂的webview都会携带自家的UA信息,比如说:

QQ:MQQBrowser/6.2 TBS/043221 Safari/537.36 QQ/7.0.0.3135
微信:MQQBrowser/6.2 TBS 043220 Safari/537.36 MicroMessenger/6.5.8.1060 NetType/4G Language/zh_CN
支付宝:UCBrowser/11.5.0.939 UCBS/2.10.1.6 Mobile Safari/537.36 AliApp(AP/10.0.15.051805) AlipayClient/10.0.15.051805 Language/zh-Hans

这样就很轻松区分是QQ还是微信还是支付宝扫码了:

User-Agent 含有 QQ/ 为QQ
User-Agent 含有 MicroMessenger 为微信
User-Agent 含有 AlipayClient 为支付宝

既然能够区分每个软件,那就可以通过自建一个网址,通过二维码生成扫描这个网址后,判断浏览器的UA,来分发不同的收款码

大致的流程则为:

客户端扫码 -> 服务端根据 User-Agent 判断客户端类型 -> 分别返回不同的处理

重点在这里:

    例:原来每个二维码中的都是一个链接:

 QQ:https://i.qianbao.qq.com/wallet/sqrcode.htm?m=tenpay&a=1&u=17878127&ac=E04BE442991E7FFED28B3B5C3E187148F063DC3C6DACAD2983C87B482FC9E7AD&n=薛定谔的猫&f=wallet
(https 协议,无法唤醒QQ)
支付宝:HTTPS://QR.ALIPAY.COM/FKX03549OW666ME7BXWF7A
(https 协议,可直接唤醒支付宝 APP)
微信:wxp://f2f09hjzo72AAYEITIBaolV-3cvGrDjE0q7k

(微信自己的支付协议,无法唤醒微信)

然后,点击扫描完后,不管是支付宝还是微信,都会跳转到对应的链接完成支付!我们能不能加一个中间过程呢,就是我们做一个二维码,信息既不是微信也不是支付宝,而是我们的一个服务器的地址,当你扫描完后,会带着你的UA(上面有提到过,不懂就百度一下)来访问我们的服务器,这时候我们就可以根据你的UA判断你是用微信还是用支付宝扫的,然后做与之相对应的逻辑处理,这样就完成了多个二维码合一!

下面是代码实现:

代码如下:

[html]  view plain  copy
  1. <?php  
  2. $ua = $_SERVER['HTTP_USER_AGENT'];  
  3. if (strpos($ua, 'MicroMessenger')) {  
  4.     $type = 'wepay';  
  5.     $name = '微信支付';  
  6.     //微信支付链接  
  7.     $url = 'wxp://f2f09hjzo72AAYEITIBaolV-3cvGrDjE0q7k';  
  8.     $icon_img = '<img src="http://ww2.sinaimg.cn/large/005zWjpngy1fojrwgr20oj303k03kglg.jpg" width="48px" height="48px" alt="'.$name.'">';  
  9. }  
  10. elseif (strpos($ua, 'AlipayClient')) {  
  11.     //支付宝链接  
  12.     $url = 'HTTPS://QR.ALIPAY.COM/FKX03479QJ0RVOS3UJLQAE';  
  13.     header('location: ' . $url);  
  14. }  
  15. elseif (strpos($ua, 'QQ/')) {  
  16.     $type = 'qq';  
  17.     $name = 'QQ钱包支付';  
  18.     //QQ钱包支付链接  
  19.     $url = 'https://i.qianbao.qq.com/wallet/sqrcode.htm?m=tenpay&a=1&u=17878127&ac=E04BE442991E7FFED28B3B5C3E187148F063DC3C6DACAD2983C87B482FC9E7AD&n=薛定谔的猫&f=wallet';  
  20.     $icon_img = '<img src="http://ww2.sinaimg.cn/large/005zWjpngy1fojrvmp427j303k03kjrb.jpg" width="48px" height="48px" alt="'.$name.'">';  
  21. }  
  22. else {  
  23.     $type = 'other';  
  24.     $name = '打赏作者';  
  25.     $url = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];  
  26.     $icon_img = '<img src="http://ww2.sinaimg.cn/large/005zWjpngy1fojs089x6tj303k03kjr6.jpg" width="48px" height="48px" alt="'.$name.'">';  
  27. }  
  28. $qr_img = '<img src="http://qr.liantu.com/api.php?text='.urlencode($url).'">';  
  29. ?>  
  30. <!DOCTYPE html>  
  31. <html>  
  32. <head>  
  33.     <meta charset="utf-8">  
  34.     <meta name="renderer" content="webkit">  
  35.     <meta http-equiv="X-UA-Compatible" content="IE=Edge, chrome=1">  
  36.     <meta name="viewport" content="width=device-width, initial-scale=1.0">  
  37.     <title><?=$name?></title>  
  38.     <style type="text/css">  
  39.         * {margin: auto;padding: 0;border: 0;}  
  40.         html {-ms-text-size-adjust: 100%;-webkit-text-size-adjust: 100%}  
  41.         body {font-family: -apple-system, SF UI Text, Arial, Microsoft YaHei, Hiragino Sans GB, WenQuanYi Micro Hei, sans-serif;color: #333;}  
  42.         img {max-width: 100%;}  
  43.         h3 {padding: 10px;}  
  44.         .container {text-align: center;}  
  45.         .title {padding: 2em 0;background-color: #fff;}  
  46.         .content {padding: 2em 1em;color: #fff;}  
  47.         .wepay {background-color: #23ac38;}  
  48.         .qq {background-color: #4c97d5;}  
  49.         .other {background-color: #ff7055;}  
  50.     </style>  
  51. </head>  
  52. <body class="<?=$type?>">  
  53.     <div class="container">  
  54.         <div class="title"><?=$icon_img?><h1><?=$name?></h1></div>  
  55.         <div class="content"><?=$type=='other'?$qr_img.'<h3>请使用支付宝、微信、QQ客户端扫码付款</h3>':$qr_img.'<h3>扫描或长按识别二维码,向TA付款</h3>'?></div>  
  56.     </div>  
  57. </body>  
  58. </html>  
方式很多,可以根据自己需要实现!

猜你喜欢

转载自blog.csdn.net/weixin_37569048/article/details/80255118