1.進入螞蟻金服開放平台https://open.alipay.com/platform/home.htm
2.注冊賬號,登錄,選擇自研開發者,填好信息后就有了自己的管理后台了,然后找到支付寶提供的官方SDK,發現並沒有Python的,所以從github上找一個
3.創建支付應用,這就是真的創建應用了,可以先用沙箱模式

沙箱模式在下面

這里面有使用介紹
4.在個人后台管理平台上,找到沙箱賬號,這是一會要用到的東西

5.下一步,需要生成秘鑰和公鑰了,下載支付寶提供的工具,安裝好后根據頁面提示使用
6.從github上找到一個SDK(python版本)
7.使用這個SDK,需要先安裝一個插件pip3 install pycryptodome,而且是Python3環境
8.修改代碼:
from django.shortcuts import render,HttpResponse,redirect from utils.pay import AliPay import time import random def ali(request): app_id = "2016082600315086" # POST # notify_url = "http://47.94.172.250:8804/page2/" notify_url = "http://127.0.0.1:8805/page2/" # notify_url = "http://www.wupeiqi.com:8804/page2/" # GET # return_url = "http://47.94.172.250:8804/page2/" return_url = "http://127.0.0.1:8805/page2/" # return_url = "http://www.wupeiqi.com:8804/page2/" # merchant_private_key_path = "keys/pri" # alipay_public_key_path = "keys/pub" merchant_private_key_path = "keys/app_private_2048.txt" alipay_public_key_path = "keys/alipay_public_2048.txt" alipay = AliPay( appid=app_id, app_notify_url=notify_url, return_url=return_url, app_private_key_path=merchant_private_key_path, alipay_public_key_path=alipay_public_key_path, # 支付寶的公鑰,驗證支付寶回傳消息使用,不是你自己的公鑰 debug=True, # 默認False, ) return alipay def pay1(request): if request.method == "GET": return render(request, 'page1.html') else: money = float(request.POST.get('money')) alipay = ali(request) # 生成支付的url query_params = alipay.direct_pay( subject="充氣式韓紅", # 商品簡單描述 out_trade_no="x2" + str(time.time()), # 商戶訂單號 total_amount=money, # 交易金額(單位: 元 保留倆位小數) ) pay_url = "https://openapi.alipaydev.com/gateway.do?{}".format(query_params) return redirect(pay_url) def pay2(request): alipay = ali(request) if request.method == "POST": # 檢測是否支付成功 # 去請求體中獲取所有返回的數據:狀態/訂單號 from urllib.parse import parse_qs body_str = request.body.decode('utf-8')#request.body拿到的是bytes post_data = parse_qs(body_str) #post傳來的數據可能有兩種形式, #可能是直接是json格式的字典(這種直接就json.loads), #還有一種就是k1=v1&k2=v2這種格式,所以這個方法就是幫我們分別判斷並處理成字典形式 post_dict = {} for k, v in post_data.items(): post_dict[k] = v[0] print(post_dict) sign = post_dict.pop('sign', None) status = alipay.verify(post_dict, sign) print('POST驗證', status) return HttpResponse('POST返回') else: params = request.GET.dict() sign = params.pop('sign', None) status = alipay.verify(params, sign)#驗證參數和用戶證書是否匹配,如果不是用的支付寶的公鑰,這里就通過不了 print('GET驗證', status) return HttpResponse('支付成功')
路由也就這兩個:
urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^page1/', views.page1), url(r'^page2/', views.page2), ]
其中,關於秘鑰的部分,下載了秘鑰工具后,用2048那個,然后拿到公鑰,復制到這
然后把右邊的支付寶公鑰復制到代碼中,軟件生成的私鑰也復制到代碼中,注意加上兩個頭
這種格式
-----BEGIN RSA PRIVATE KEY----- MIIEogIBAAKCAQEAzt3sPpGlmqW+8W+42avQZ50YgfAVKK9bt/RBTsDPyN5uq。。。。。。。 -----END RSA PRIVATE KEY-----
然后就沒啥了
