1. 支付寶開放平台登錄,使用支付寶賬號登錄
https://open.alipay.com/platform/home.htm
2.選擇沙箱模式 【支付寶提供了測試環境】
https://docs.open.alipay.com/200/105311
3.支付寶開發者文檔
https://openhome.alipay.com/developmentDocument.htm
4.電腦網站支付
https://docs.open.alipay.com/270,查看支付流程和支付接口介紹
5.因為官方並沒有提供Python語言的SDK,但是在github上有大神提供了二次封裝過的工具
https://github.com/fzlee/alipay/blob/master/README.zh-hans.md
使用:pip install python-alipay-sdk --upgrade
6.github網址中提供了pc端,移動端對應的使用方法,下面以pc端為例,進行演示
原理介紹:
1.進行秘鑰配置,因為傳輸的數據必須要進行簽名加密,ubuntu內置命令openssl可以生成私鑰,根據私鑰生成公鑰
openssl
OpenSSL> genrsa -out app_private_key.pem 2048 # 私鑰 2048對應的是rsa加密時候的復雜程度,即rsa2
OpenSSL> rsa -in app_private_key.pem -pubout -out app_public_key.pem # 導出公鑰
OpenSSL> exit
2.cat app_publict_key.pem 查看公鑰的內容
將-----BEGIN PUBLIC KEY-----和-----END PUBLIC KEY-----中間的內容保存在支付寶的用戶配置中(沙箱或者正式)
https://openhome.alipay.com/platform/appDaily.htm?tab=info
3.配置好公鑰后,支付寶會生成公鑰,將公鑰的內容復制保存到一個文本文件中(alipay_pubilc_key.pem),注意需要在文本的首尾添加標記位(-----BEGIN PUBLIC KEY-----和-----END PUBLIC KEY-----)
4.將剛剛生成的私鑰app_private_key.pem和支付寶公鑰alipay_public_key.pem放到我們的項目目錄中
5.使用支付寶 python包的初始化
6.調用支付接口
https://docs.open.alipay.com/270/alipay.trade.page.pay/
7.獲取支付結果接口
https://docs.open.alipay.com/api_1/alipay.trade.query
7.代碼實現,這是一個簡單的demo,在真正項目開發中,只用把沙箱環境更改成正式環境就可以,其他一切都是一樣的
1.文件目錄
2.index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="static/js/jquery-1.12.4.min.js"></script> <script> $(function () { $('#btn').click(function () { var order_id = "20171123002" var req_data = { order_id: order_id, csrfmiddlewaretoken: "{{ csrf_token }}" } $.post("/pay/", req_data, function (data) { window.open(data.url) }) $.get("/check_pay/?order_id=" + order_id, function (data) { if (0 == data.code) { // 支付成功 alert("支付成功"); location.reload(); } else { alert(data.message) } }) }) }) </script> </head> <body> <input type="button" id="btn" value="支付"> </body> </html>
3.主路由,即pay_test下urls.py
from django.conf.urls import url,include from django.contrib import admin urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^', include('app_test.urls')), ]
應用app_test下的urls.py
from django.conf.urls import url from . import views urlpatterns=[ url(r"^$",views.index), url(r"^pay/$",views.pay), url(r"^check_pay/$", views.check_pay), ]
4.視圖函數views.py
from django.shortcuts import render from django.http import JsonResponse from alipay import AliPay import os from django.conf import settings def index(request): return render(request, "index.html") def pay(request): order_id = request.POST.get("order_id") # 創建用於進行支付寶支付的工具對象 alipay = AliPay( appid=settings.ALIPAY_APPID, app_notify_url=None, # 默認回調url app_private_key_path=os.path.join(settings.BASE_DIR, "app_test/app_private_key.pem"), alipay_public_key_path=os.path.join(settings.BASE_DIR, "app_test/alipay_public_key.pem"), # 支付寶的公鑰,驗證支付寶回傳消息使用,不是你自己的公鑰, sign_type="RSA2", # RSA 或者 RSA2 debug=True # 默認False 配合沙箱模式使用 ) # 電腦網站支付,需要跳轉到https://openapi.alipay.com/gateway.do? + order_string order_string = alipay.api_alipay_trade_page_pay( out_trade_no=order_id, total_amount=str(0.01), # 將Decimal類型轉換為字符串交給支付寶 subject="商貿商城", return_url=None, notify_url=None # 可選, 不填則使用默認notify url ) # 讓用戶進行支付的支付寶頁面網址 url = settings.ALIPAY_URL + "?" + order_string return JsonResponse({"code": 0, "message": "請求支付成功", "url": url}) def check_pay(request): # 創建用於進行支付寶支付的工具對象 order_id = request.GET.get("order_id") alipay = AliPay( appid=settings.ALIPAY_APPID, app_notify_url=None, # 默認回調url app_private_key_path=os.path.join(settings.BASE_DIR, "app_test/app_private_key.pem"), alipay_public_key_path=os.path.join(settings.BASE_DIR, "app_test/alipay_public_key.pem"), # 支付寶的公鑰,驗證支付寶回傳消息使用,不是你自己的公鑰, sign_type="RSA2", # RSA2,官方推薦,配置公鑰的時候能看到 debug=True # 默認False 配合沙箱模式使用 ) while True: # 調用alipay工具查詢支付結果 response = alipay.api_alipay_trade_query(order_id) # response是一個字典 # 判斷支付結果 code = response.get("code") # 支付寶接口調用成功或者錯誤的標志 trade_status = response.get("trade_status") # 用戶支付的情況 if code == "10000" and trade_status == "TRADE_SUCCESS": # 表示用戶支付成功 # 返回前端json,通知支付成功 return JsonResponse({"code": 0, "message": "支付成功"}) elif code == "40004" or (code == "10000" and trade_status == "WAIT_BUYER_PAY"): # 表示支付寶接口調用暫時失敗,(支付寶的支付訂單還未生成) 后者 等待用戶支付 # 繼續查詢 print(code) print(trade_status) continue else: # 支付失敗 # 返回支付失敗的通知 return JsonResponse({"code": 1, "message": "支付失敗"})
5.settings.py下加下面兩句話
STATIC_URL = '/static/' STATICFILES_DIRS = [os.path.join(BASE_DIR, "static")] # 支付寶配置參數 ALIPAY_APPID = "你的應用id" ALIPAY_URL = "https://openapi.alipaydev.com/gateway.do"