自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

制作QQ微信支付寶三合一收款碼

開發(fā) 后端 移動(dòng)開發(fā)
最近在逛博客時(shí),發(fā)現(xiàn)很多博客都帶了打賞功能,雖說打賞的人可能很少,但始終是一份心意,能讓博主知道自己寫的文章有用,能夠幫助到人。所以,我也想加一個(gè)打賞功能~

前言

最近在逛博客時(shí),發(fā)現(xiàn)很多博客都帶了打賞功能,雖說打賞的人可能很少,但始終是一份心意,能讓博主知道自己寫的文章有用,能夠幫助到人。所以,我也想加一個(gè)打賞功能~

分析

但在github逛了一圈之后發(fā)現(xiàn),打賞插件基本上千篇一律的:QQ掃碼/微信掃碼/支付寶掃碼。

[[220620]]

有的是點(diǎn)擊每個(gè)按鈕出現(xiàn)每個(gè)收款碼

有的則是每個(gè)收款碼全部展現(xiàn)出來

微信掃這個(gè),支付寶掃那個(gè),不僅要加載多張二維碼,還要加css/js讓它變的好看,作為一個(gè)又懶又不想寫這些東西的程序猿來說,這可不行。

那能不能把QQ微信支付寶三合一,只需要掃一個(gè)收款碼就行呢?

這里涉及到一個(gè)知識(shí)點(diǎn),則是User-Agent,大廠的webview都會(huì)攜帶自家的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.05180***lipayClient/10.0.15.051805 Language/zh-Hans

這樣就很輕松區(qū)分是QQ還是微信還是支付寶掃碼了:

User-Agent 含有 QQ/ 為QQ

User-Agent 含有 MicroMessenger 為微信

User-Agent 含有 AlipayClient 為支付寶

既然能夠區(qū)分每個(gè)軟件,那就可以通過自建一個(gè)網(wǎng)址,通過二維碼生成掃描這個(gè)網(wǎng)址后,判斷瀏覽器的UA,來分發(fā)不同的收款碼

大致的流程則為:

客戶端掃碼 -> 服務(wù)端根據(jù) User-Agent 判斷客戶端類型 -> 分別返回不同的處理

開始折騰

首先解碼QQ、微信和支付寶生成的付款碼,可以去這里在線解碼。

QQ:https://i.qianbao.qq.com/wallet/sqrcode.htm?m=tenpay&a=1&u=17878127&ac=E04BE442991E7FFED28B3B5C3E187148F063DC3C6DACAD2983C87B482FC9E7AD&n=薛定諤的貓&f=wallet

(https 協(xié)議,無法喚醒QQ)

支付寶:HTTPS://QR.ALIPAY.COM/FKX03549OW666ME7BXWF7A

(https 協(xié)議,可直接喚醒支付寶 APP)

微信:wxp://f2f09hjzo72AAYEITIBaolV-3cvGrDjE0q7k

(微信自己的支付協(xié)議,無法喚醒微信)

下面就可以直接寫代碼了,判斷 User-Agent 如果是支付寶直接跳轉(zhuǎn)支付寶鏈接,如果是QQ和微信則跳轉(zhuǎn)QQ和微信的鏈接。

但由于QQ與微信無法直接喚醒APP,所以直接輸出一個(gè)QQ與微信的二維碼,然后長(zhǎng)按掃碼實(shí)現(xiàn)支付。

代碼如下:

 

  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>請(qǐng)使用支付寶、微信、QQ客戶端掃碼付款</h3>':$qr_img.'<h3>掃描或長(zhǎng)按識(shí)別二維碼,向TA付款</h3>'?></div>  
  56.     </div>  
  57. </body>  
  58. </html> 

Demo演示

可以通過掃描文章底部的二維碼進(jìn)行測(cè)試,或點(diǎn)擊下面的演示地址:

http://lab.sangsir.com/api/do... 

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2021-11-26 21:27:07

支付寶微信商家

2021-11-26 17:20:05

微信支付寶收款碼

2009-03-10 08:31:33

Lunascape瀏覽器

2021-11-27 07:08:39

微信支付寶收款碼

2012-02-20 15:04:36

2015-06-19 15:37:07

2021-11-30 07:31:42

微信支付寶付款

2021-11-26 12:04:52

微信支付寶收款碼

2021-11-29 10:15:10

微信支付寶收款碼

2022-02-23 07:53:09

收款碼支付寶微信

2017-06-12 12:23:46

打印機(jī)文印產(chǎn)品Brother

2013-11-28 11:15:43

微信支付寶支付戰(zhàn)爭(zhēng)

2022-02-21 09:28:11

微信支付寶收款碼

2018-03-21 06:27:16

支付寶微信銀聯(lián)

2013-06-07 11:22:28

2018-07-01 15:40:51

微信支付寶央行

2019-11-01 09:36:58

微信支付支付寶

2021-10-12 15:35:36

微信支付寶銀聯(lián)云閃付

2018-03-22 04:20:40

支付寶微信移動(dòng)支付

2021-01-19 16:24:08

抖音支付寶微信
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)