python支付宝支付示例详解


Posted in Python onAugust 22, 2019

本文实例为大家分享了python支付宝支付示例代码,供大家参考,具体内容如下

项目演示:

1、输入金额

python支付宝支付示例详解

2、扫码支付:

python支付宝支付示例详解

3、支付完成:

python支付宝支付示例详解

python支付宝支付示例详解

一、注册账号

https://openhome.alipay.com/platform/appDaily.htm?tab=info

二、设置应用公钥

python支付宝支付示例详解

python支付宝支付示例详解

python支付宝支付示例详解

python支付宝支付示例详解

python支付宝支付示例详解

三、代码实现

1、项目结构:

python支付宝支付示例详解

2、把生成的     应用私钥     和    支付宝的公钥       放入keys目录下:

注意:

支付宝公钥

商户私钥

--- 配置商户应用私钥--copy到key目录下

python支付宝支付示例详解

python支付宝支付示例详解

--- 配置支付宝公钥--进入网页-->查看支付宝公钥-->把公钥放到key目录下

python支付宝支付示例详解

但是要做修改:

python支付宝支付示例详解

alipay_public_2048.txt
 -----BEGIN PUBLIC KEY----- # 加上这行
 支付宝的公钥
 -----END PUBLIC KEY----- # 同上
 
app_private_2048.txt
 -----BEGIN PUBLIC KEY----- #同上
 应用的私钥
 -----END PUBLIC KEY----- # 同上

3、pay.py 这是从git上找到的支付宝支付接口(PC端支付接口) 

python支付宝支付示例详解

in pay.py

from datetime import datetime
from Crypto.PublicKey import RSA
from Crypto.Signature import PKCS1_v1_5
from Crypto.Hash import SHA256
from urllib.parse import quote_plus
from urllib.parse import urlparse, parse_qs
from base64 import decodebytes, encodebytes
import json
 
class AliPay(object):
 """
 支付宝支付接口(PC端支付接口)
 """
 
 def __init__(self, appid, app_notify_url, app_private_key_path,
  alipay_public_key_path, return_url, debug=False):
 self.appid = appid
 self.app_notify_url = app_notify_url
 self.app_private_key_path = app_private_key_path
 self.app_private_key = None
 self.return_url = return_url
 with open(self.app_private_key_path) as fp:
 self.app_private_key = RSA.importKey(fp.read())
 self.alipay_public_key_path = alipay_public_key_path
 with open(self.alipay_public_key_path) as fp:
 self.alipay_public_key = RSA.importKey(fp.read())
 
 if debug is True:
 self.__gateway = "https://openapi.alipaydev.com/gateway.do"
 else:
 self.__gateway = "https://openapi.alipay.com/gateway.do"
 
 def direct_pay(self, subject, out_trade_no, total_amount, return_url=None, **kwargs):
 biz_content = {
 "subject": subject,
 "out_trade_no": out_trade_no,
 "total_amount": total_amount,
 "product_code": "FAST_INSTANT_TRADE_PAY",
 # "qr_pay_mode":4
 }
 
 biz_content.update(kwargs)
 data = self.build_body("alipay.trade.page.pay", biz_content, self.return_url)
 return self.sign_data(data)
 
 def build_body(self, method, biz_content, return_url=None):
 data = {
 "app_id": self.appid,
 "method": method,
 "charset": "utf-8",
 "sign_type": "RSA2",
 "timestamp": datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
 "version": "1.0",
 "biz_content": biz_content
 }
 
 if return_url is not None:
 data["notify_url"] = self.app_notify_url
 data["return_url"] = self.return_url
 
 return data
 
 def sign_data(self, data):
 data.pop("sign", None)
 # 排序后的字符串
 unsigned_items = self.ordered_data(data)
 unsigned_string = "&".join("{0}={1}".format(k, v) for k, v in unsigned_items)
 sign = self.sign(unsigned_string.encode("utf-8"))
 # ordered_items = self.ordered_data(data)
 quoted_string = "&".join("{0}={1}".format(k, quote_plus(v)) for k, v in unsigned_items)
 
 # 获得最终的订单信息字符串
 signed_string = quoted_string + "&sign=" + quote_plus(sign)
 return signed_string
 
 def ordered_data(self, data):
 complex_keys = []
 for key, value in data.items():
 if isinstance(value, dict):
 complex_keys.append(key)
 
 # 将字典类型的数据dump出来
 for key in complex_keys:
 data[key] = json.dumps(data[key], separators=(',', ':'))
 
 return sorted([(k, v) for k, v in data.items()])
 
 def sign(self, unsigned_string):
 # 开始计算签名
 key = self.app_private_key
 signer = PKCS1_v1_5.new(key)
 signature = signer.sign(SHA256.new(unsigned_string))
 # base64 编码,转换为unicode表示并移除回车
 sign = encodebytes(signature).decode("utf8").replace("\n", "")
 return sign
 
 def _verify(self, raw_content, signature):
 # 开始计算签名
 key = self.alipay_public_key
 signer = PKCS1_v1_5.new(key)
 digest = SHA256.new()
 digest.update(raw_content.encode("utf8"))
 if signer.verify(digest, decodebytes(signature.encode("utf8"))):
 return True
 return False
 
 def verify(self, data, signature):
 if "sign_type" in data:
 sign_type = data.pop("sign_type")
 # 排序后的字符串
 unsigned_items = self.ordered_data(data)
 message = "&".join(u"{}={}".format(k, v) for k, v in unsigned_items)
 return self._verify(message, signature)

3、路由设置

in urls.py

urlpatterns = [
 url(r'^admin/', admin.site.urls),
 url(r'^page1/', views.page1),
 url(r'^index/', views.index),
 url(r'^page2/', views.page2),
 ]

4、视图设置

in  view.py

from django.shortcuts import render, redirect, HttpResponse
 from utils.pay import AliPay
 import json
 import time
 
 
 def get_ali_object():
 # 沙箱环境地址:https://openhome.alipay.com/platform/appDaily.htm?tab=info
 app_id = "2016091100486897" # APPID (沙箱应用)
 
 # 支付完成后,支付偷偷向这里地址发送一个post请求,识别公网IP,如果是 192.168.20.13局域网IP ,支付宝找不到,def page2() 
 # 接收不到这个请求
 notify_url = "http://47.94.172.250:8804/page2/"
 
 # 支付完成后,跳转的地址。
 return_url = "http://47.94.172.250:8804/page2/"
 
 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 index(request):
 return render(request,'index.html')
 
 def page1(request):
 # 根据当前用户的配置,生成URL,并跳转。 
 money = float(request.POST.get('money'))
 
 alipay = get_ali_object()
 
 # 生成支付的url
 query_params = alipay.direct_pay(
 subject="充气式赵俊明", # 商品简单描述
 out_trade_no="x2" + str(time.time()), # 用户购买的商品订单号(每次不一样) 20180301073422891
 total_amount=money, # 交易金额(单位: 元 保留俩位小数)
 )
 
 pay_url = "https://openapi.alipaydev.com/gateway.do?{0}".format(query_params) # 支付宝网关地址(沙箱应用)
 
 return redirect(pay_url)
 
 
 def page2(request):
 alipay = get_ali_object()
 if request.method == "POST":
 # 检测是否支付成功
 # 去请求体中获取所有返回的数据:状态/订单号
 from urllib.parse import parse_qs
 # name&age=123....
 body_str = request.body.decode('utf-8')
 post_data = parse_qs(body_str)
 
 post_dict = {}
 for k, v in post_data.items():
 post_dict[k] = v[0]
 
 # post_dict有10key: 9 ,1
 sign = post_dict.pop('sign', None)
 status = alipay.verify(post_dict, sign)
 print('------------------开始------------------')
 print('POST验证', status)
 print(post_dict)
 out_trade_no = post_dict['out_trade_no']
 
 # 修改订单状态
 # models.Order.objects.filter(trade_no=out_trade_no).update(status=2)
 print('------------------结束------------------')
 # 修改订单状态:获取订单号
 return HttpResponse('POST返回')
 
 else:
 params = request.GET.dict()
 sign = params.pop('sign', None)
 status = alipay.verify(params, sign)
 print('==================开始==================')
 print('GET验证', status)
 print('==================结束==================')
 return HttpResponse('支付成功')

5、模板

in index.html

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
 <link rel="stylesheet" href="dist/css/bootstrap.css" rel="external nofollow" >
</head>
<body>
 <form action="/page1/" method="POST">
 {% csrf_token %}
 <input type="text" name="money">
 <input type="submit" value="去支付" />
 </form>
<script></script>
</body>
</html>

6、当你全部设置完,代码只需修改三个地方

git项目地址

 (1)、修改APPID

-- 这是你账号的APPID       

python支付宝支付示例详解

-- in  views.py

def  get_ali_object():

 app_id = 'xxxxxxx' #你的账号APPID  

================================

python支付宝支付示例详解

(2)、换上你的支付宝公钥

(3)、换上你的应用私钥

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python工程师面试题 与Python基础语法相关
Jan 14 Python
在Ubuntu系统下安装使用Python的GUI工具wxPython
Feb 18 Python
Python编程实现使用线性回归预测数据
Dec 07 Python
python安装教程
Feb 28 Python
python获取酷狗音乐top500的下载地址 MP3格式
Apr 17 Python
在Python 中同一个类两个函数间变量的调用方法
Jan 31 Python
Python秒算24点实现及原理详解
Jul 29 Python
Django获取该数据的上一条和下一条方法
Aug 12 Python
python global关键字的用法详解
Sep 05 Python
基于python使用tibco ems代码实例
Dec 20 Python
全网首秀之Pycharm十大实用技巧(推荐)
Apr 27 Python
Django展示可视化图表的多种方式
Apr 08 Python
关于python3中setup.py小概念解析
Aug 22 #Python
python3 requests库文件上传与下载实现详解
Aug 22 #Python
python3使用print打印带颜色的字符串代码实例
Aug 22 #Python
Python检查 云备份进程是否正常运行代码实例
Aug 22 #Python
浅谈Python 递归算法指归
Aug 22 #Python
python求加权平均值的实例(附纯python写法)
Aug 22 #Python
python求平均数、方差、中位数的例子
Aug 22 #Python
You might like
Zend的AutoLoad机制介绍
2012/09/27 PHP
PHP获取文件后缀名的三个函数
2012/10/15 PHP
php 判断服务器操作系统的类型
2014/02/17 PHP
thinkphp缓存技术详解
2014/12/09 PHP
PHP检测链接是否存在的代码实例分享
2016/05/06 PHP
JavaScript写的一个自定义弹出式对话框代码
2010/01/17 Javascript
js中查找最近的共有祖先元素的实现代码
2010/12/30 Javascript
Array的push与unshift方法性能比较分析
2011/03/05 Javascript
jquery序列化form表单使用ajax提交后处理返回的json数据
2014/03/03 Javascript
简介JavaScript中的setDate()方法的使用
2015/06/11 Javascript
jQuery实现可编辑的表格实例讲解(2)
2015/09/17 Javascript
jQuery简单实现页面元素置顶时悬浮效果示例
2016/08/01 Javascript
如何理解jQuery中的ajaxSubmit方法
2017/03/13 Javascript
浅谈es6 javascript的map数据结构
2017/12/14 Javascript
微信小程序实现倒计时调用相机自动拍照功能
2018/06/10 Javascript
js实现导航跟随效果
2018/11/17 Javascript
JavaScript实现Excel表格效果
2020/02/07 Javascript
浅析JS中NEW的实现原理及重写
2020/02/20 Javascript
JS typeof fn === 'function' &amp;&amp; fn()详解
2020/08/22 Javascript
[45:52]2018DOTA2亚洲邀请赛 4.1小组赛 A组加赛 LGD vs Liquid
2018/04/02 DOTA
神经网络(BP)算法Python实现及应用
2018/04/16 Python
Sanic框架流式传输操作示例
2018/07/18 Python
把JSON数据格式转换为Python的类对象方法详解(两种方法)
2019/06/04 Python
Python Numpy 实现交换两行和两列的方法
2019/06/26 Python
Python操作远程服务器 paramiko模块详细介绍
2019/08/07 Python
python 图像判断,清晰度(明暗),彩色与黑白实例
2020/06/04 Python
python用700行代码实现http客户端
2021/01/14 Python
纯CSS3实现Material Design效果
2017/03/09 HTML / CSS
html5教你做炫酷的碎片式图片切换 (canvas)
2017/07/28 HTML / CSS
Brydge英国:适用于Apple iPad和Microsoft Surface Pro的蓝牙键盘
2019/05/16 全球购物
员工工作表现评语
2014/04/26 职场文书
师德师风个人反思
2014/04/28 职场文书
公司授权委托书格式范文
2014/10/02 职场文书
优秀党员先进事迹材料2016
2016/02/29 职场文书
MySQL的join buffer原理
2021/04/29 MySQL
52条SQL语句教你性能优化
2021/05/25 MySQL