移動支付的普及越來越廣,像地鐵站的無人售貨機,小區的快遞柜,停車場的充電樁等,這些設備大部分集成了掃碼支付功能。今天,我們就以項目的形式介紹如何為Linux工控機接入微信掃碼支付。
一、硬件環境
整體硬件連接框架如圖 1所示:
圖1 硬件連接圖
二、演示效果
先看看最終的效果,客戶端使用Qt框架編寫,其啟動界面如圖 2所示:
圖2 演示Demo主界面
點擊小鍵盤,輸入支付金額,點擊確定后客戶端將與服務器進行通信,拿到支付鏈接,本地生成支付二維碼,如圖 3所示:
圖3 生成支付二維碼
接下來打開手機微信客戶端,使用掃一掃進行掃碼,根據支付頁面提示輸入支付密碼,支付結果如圖 4所示:
圖4 支付結果
完成支付后,演示客戶端界面上將顯示支付成功字樣,如圖 5所示:
圖5 顯示支付結果
掃碼接入為何如何容易?服務器客戶端應該怎么處理?PHP是不是世界上最好的語言?說好的源碼究竟在哪里?敬請關注本文以下章節。
三、系統流程
整個項目采用CS架構,分為嵌入式Linux客戶端、后臺服務器以及手機客戶端三部分,系統流程如圖 6所示:
圖6 系統流程圖
從系統流程圖中可以看到,我們需要編寫客戶端和服務器端的代碼,客戶端我們使用的是QT框架,服務器端我們直接使用微信官方的支付SDK包。在客戶端與服務器的交互過程中,最主要的是拿到微信支付的鏈接地址以及訂單號,鏈接地址為了生成二維碼圖片,訂單號為了查詢支付狀態。
四、服務器端實現
從微信官方下載SDK(文末有鏈接),有JAVA、.NET C#、PHP三種類型的SDK提供,如圖 7所示:
圖7 微信SDK
這里我們選擇PHP版本進行下載,服務器端環境為Ubuntu14.04系統,采用nginx進行搭建,端口號8080。(必答題:PHP是世界上___的語言)
1、PHP+NGINX環境搭建
我們在Ubuntu主機上進行nginx服務器的搭建,具體步驟為安裝-配置-啟動。
安裝nginx服務器:
配置nginx服務器,為了不與其它服務器監聽端口號沖突,我們直接修改nginx服務器的配置,將默認的80端口修改為8080,修改過程如下:
啟動nginx服務器:
由于我們使用的是微信官方SDK的PHP版本,所以我們需要為系統裝上PHP環境,同時需要修改nginx服務器的配置,使其支持PHP。
安裝PHP環境比較簡單,Ubuntu 14.04中的安裝命令如下:
接下來修改nginx服務器配置,使其支持PHP:
在/usr/share/nginx/html目錄下新建index.php,重啟php5-fpm和nginx進行測試:
打開本地瀏覽器,輸入地址localhost:8080即可看到對應PHP頁面,如圖 8所示,此時PHP+NGINX環境搭建已完成。
圖8 PHP+NGINX測試結果
2、微信SDK安裝及修改
將下載好的微信支付PHP版本的SDK進行解壓,并將相關文件拷貝到nginx服務器根目錄(默認為/usr/share/nginx/html,可通過修改/etc/nginx/sitesavailable/default的root參數進行指定,這里我們使用默認參數):
本地瀏覽器中輸入地址服務器地址,可以看到微信SDK已經運行起來了,如圖 9所示:
圖9 微信SDK頁面
接下來我們需要對SDK進行修改,主要是替換商戶信息,SSL服務端驗證禁用,支付接口實現,查詢接口實現等。
-
替換商戶信息
要使用微信支付,必須先開通公眾號或企業號微信支付的相關功能,這里不對如何開通做過多說明,在開通微信支付后,微信會提供商戶信息,如商戶號、支付秘鑰等。我們需要替換/lib/WxPay.Config.php文件的商戶信息(SDK中的文件,已經被我們拷貝到nginx服務器根目錄),修改的位置如下:
-
SSL服務端驗證禁用
下載的SDK包為V3版本,在低版本的SSL庫上運行會出現錯誤,我們直接禁用SSL服務端驗證功能,修改/lib/WxPay.Api.php文件,將postXmlCurl函數中的SSL服務端驗證功能禁用,修改如下:
-
支付接口實現
掃碼支付接口位于/example/native.php文件中,原生SDK包中有示例代碼,我們對其進行修改,實現的執行流程為獲取輸入金額→請求微信支付鏈接→下發鏈接地址及訂單號,這里我們使用了分隔符簡單進行數據的封裝,實際應用中可以加入JSON或XML格式的響應報文。修改后的代碼如下:
-
查詢接口實現
訂單查詢接口位于/example/orderquery.php文件中,我們對其進行修改,當客戶端POST訂單號到該接口后,將進行相應訂單號的支付狀態查詢,然后返回支付狀態。修改后代碼如下:
以上四步完成了微信SDK的安裝和修改,同時實現了支付接口以及查詢接口,至此,服務器部署已完成。
五、客戶端實現
客戶端使用Qt框架編寫,其中需要處理的幾個關鍵點有二維碼圖片生成、網絡通信及數據解析,下面介紹各個部分實現的重點。
1、二維碼圖片生成
我們使用了開源的QRencode進行二維碼圖片的生成,可以將QRencode的源碼集成進Qt工程中調用,也可以使用編譯好的QRencode可執行文件進行調用。
這里我們直接編譯QRencode源碼,編譯依賴zlib以及libpng庫,為了編譯方便,源碼包中提供了一個自動化編譯腳本,編譯過程如下:
編譯完成后,可以得到qrencode二維碼生成工具,其大致用法如下:
在Qt中調用該工具顯示二維碼的代碼如下:
2、網絡通信及數據解析
我們使用了Qt的QNetworkRequest模塊進行網絡通信,將相關功能封裝成Post函數供調用,與服務器交互及數據解析的代碼如下:
這里說明下硬件連接方式,首先服務器為Ubuntu主機,工控機通過網線將百兆網口與服務器直連,形成一個局域網。而本項目中服務器局域網地址為192.168.1.164,所以在源碼中直接指定了服務器地址,當使用無線上網時可以修改服務器地址為遠程服務器的公網IP地址(重大消息:DCP-3000L工控機自帶4G無線上網功能,同時具備全網通撥號守護腳本,支持斷線重撥,流量異常檢測,三網自動識別。)。
客戶端剩下的就是界面的邏輯處理啦,在第一小節部分我們已經看到了演示的效果,就不在詳細介紹了。項目中支付完成后是顯示支付完成并等待下一次支付,而在實際應用中往往是進行硬件操作,如打開繼電器開關,播放音樂等等。至此,微信掃碼支付已介紹完畢,源碼往下拉。
六、說好的源碼
源碼github地址:
https://github.com/kp339/qt-wxpay.git
-
嵌入式系統
+關注
關注
41文章
3594瀏覽量
129534 -
微信
+關注
關注
6文章
512瀏覽量
26612 -
掃碼器
+關注
關注
0文章
95瀏覽量
5854
原文標題:【工程師必讀】如何實現微信掃碼支付?
文章出處:【微信號:ZLG_zhiyuan,微信公眾號:ZLG致遠電子】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論