热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python支付宝自动支付_python支付宝支付流程

1.项目展示:2.扫码支付3.支付完成4.跳转成功一、注册账号https:openhome.alipay.complatformappDaily.htm?tabinf

1.项目展示:

2.扫码支付

3.支付完成

4.跳转成功

一、注册账号

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

二、设置应用公钥

私钥需要复制到程序里的:

程序里面阿里的公钥在这里获取:

这里放的是阿里的公钥。

代码实现:

代码结构:

1. 首先是:更改程序里面的阿里公钥和用户私钥以及app_id

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

3、

1 from datetime importdatetime2 from Crypto.PublicKey importRSA3 from Crypto.Signature importPKCS1_v1_54 from Crypto.Hash importSHA2565 from urllib.parse importquote_plus6 from urllib.parse importurlparse, parse_qs7 from base64 importdecodebytes, encodebytes8 importjson9

10 classAliPay(object):11 """

12 支付宝支付接口(PC端支付接口)13 """

14

15 def __init__(self, appid, app_notify_url, app_private_key_path,16 alipay_public_key_path, return_url, debug=False):17 self.appid =appid18 self.app_notify_url =app_notify_url19 self.app_private_key_path =app_private_key_path20 self.app_private_key =None21 self.return_url =return_url22 with open(self.app_private_key_path) as fp:23 self.app_private_key =RSA.importKey(fp.read())24 self.alipay_public_key_path =alipay_public_key_path25 with open(self.alipay_public_key_path) as fp:26 self.alipay_public_key =RSA.importKey(fp.read())27

28 if debug isTrue:29 self.__gateway = "https://openapi.alipaydev.com/gateway.do"

30 else:31 self.__gateway = "https://openapi.alipay.com/gateway.do"

32

33 def direct_pay(self, subject, out_trade_no, total_amount, return_url=None, **kwargs):34 biz_content ={35 "subject": subject,36 "out_trade_no": out_trade_no,37 "total_amount": total_amount,38 "product_code": "FAST_INSTANT_TRADE_PAY",39 #"qr_pay_mode":4

40 }41

42 biz_content.update(kwargs)43 data = self.build_body("alipay.trade.page.pay", biz_content, self.return_url)44 returnself.sign_data(data)45

46 def build_body(self, method, biz_content, return_url=None):47 data ={48 "app_id": self.appid,49 "method": method,50 "charset": "utf-8",51 "sign_type": "RSA2",52 "timestamp": datetime.now().strftime("%Y-%m-%d %H:%M:%S"),53 "version": "1.0",54 "biz_content": biz_content55 }56

57 if return_url is notNone:58 data["notify_url"] =self.app_notify_url59 data["return_url"] =self.return_url60

61 returndata62

63 defsign_data(self, data):64 data.pop("sign", None)65 #排序后的字符串

66 unsigned_items =self.ordered_data(data)67 unsigned_string = "&".join("{0}={1}".format(k, v) for k, v inunsigned_items)68 sign = self.sign(unsigned_string.encode("utf-8"))69 #ordered_items = self.ordered_data(data)

70 quoted_string = "&".join("{0}={1}".format(k, quote_plus(v)) for k, v inunsigned_items)71

72 #获得最终的订单信息字符串

73 signed_string = quoted_string + "&sign=" +quote_plus(sign)74 returnsigned_string75

76 defordered_data(self, data):77 complex_keys =[]78 for key, value indata.items():79 ifisinstance(value, dict):80 complex_keys.append(key)81

82 #将字典类型的数据dump出来

83 for key incomplex_keys:84 data[key] = json.dumps(data[key], separators=(',', ':'))85

86 return sorted([(k, v) for k, v indata.items()])87

88 defsign(self, unsigned_string):89 #开始计算签名

90 key =self.app_private_key91 signer =PKCS1_v1_5.new(key)92 signature =signer.sign(SHA256.new(unsigned_string))93 #base64 编码,转换为unicode表示并移除回车

94 sign = encodebytes(signature).decode("utf8").replace("\n", "")95 returnsign96

97 def_verify(self, raw_content, signature):98 #开始计算签名

99 key =self.alipay_public_key100 signer =PKCS1_v1_5.new(key)101 digest =SHA256.new()102 digest.update(raw_content.encode("utf8"))103 if signer.verify(digest, decodebytes(signature.encode("utf8"))):104 returnTrue105 returnFalse106

107 defverify(self, data, signature):108 if "sign_type" indata:109 sign_type = data.pop("sign_type")110 #排序后的字符串

111 unsigned_items =self.ordered_data(data)112 message = "&".join(u"{}={}".format(k, v) for k, v inunsigned_items)113 return self._verify(message, signature)

支付函数

4.路由设置:

from django.conf.urls importurlfrom django.contrib importadminfrom app01 importviews

urlpatterns=[

url(r'^admin/', admin.site.urls),

url(r'^page1/', views.page1),

url(r'^index/', views.index),

url(r'^page2/', views.page2),

]

5.视图:

from django.shortcuts importrender, redirect, HttpResponsefrom utils.pay importAliPayimportjsonimporttimedefali():#沙箱环境地址:https://openhome.alipay.com/platform/appDaily.htm?tab=info

app_id = "2016091100483151"

#POST请求,用于最后的检测

notify_url = "http://127.0.0.1:8804/page2/"

#notify_url = "http://www.wupeiqi.com:8804/page2/"

#GET请求,用于页面的跳转展示

return_url = "http://127.0.0.1:8804/page2/"

#return_url = "http://www.wupeiqi.com: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,

)returnalipaydefindex(request):return render(request,'index.html')defpage1(request):if request.method == "GET":return render(request, 'index.html')else:

money= float(request.POST.get('money'))

alipay=ali()#生成支付的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)returnredirect(pay_url)defpage2(request):

alipay=ali()if request.method == "POST":#检测是否支付成功

#去请求体中获取所有返回的数据:状态/订单号

from urllib.parse importparse_qs

body_str= request.body.decode('utf-8')

post_data=parse_qs(body_str)

post_dict={}for k, v inpost_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('支付成功')

6.模板

Title{% csrf_token %}

注意:安装Crypto

把安装包放到C:\Users\frank\AppData\Local\Programs\Python\Python36\Lib\site-packages   然后解压缩就行了。

https://blog.csdn.net/sc_lilei/article/details/80450859



推荐阅读
  • Requests库的基本使用方法
    本文介绍了Python中Requests库的基础用法,包括如何安装、GET和POST请求的实现、如何处理Cookies和Headers,以及如何解析JSON响应。相比urllib库,Requests库提供了更为简洁高效的接口来处理HTTP请求。 ... [详细]
  • C#实现文件的压缩与解压
    2019独角兽企业重金招聘Python工程师标准一、准备工作1、下载ICSharpCode.SharpZipLib.dll文件2、项目中引用这个dll二、文件压缩与解压共用类 ... [详细]
  • 本文详细探讨了在Java中如何将图像对象转换为文件和字节数组(Byte[])的技术。虽然网络上存在大量相关资料,但实际操作时仍需注意细节。本文通过使用JMSL 4.0库中的图表对象作为示例,提供了一种实用的方法。 ... [详细]
  • 如何在Django框架中实现对象关系映射(ORM)
    本文介绍了Django框架中对象关系映射(ORM)的实现方式,通过ORM,开发者可以通过定义模型类来间接操作数据库表,从而简化数据库操作流程,提高开发效率。 ... [详细]
  • 本文探讨了如何在Python中将具有相同值的元素分组到矩阵中,这是一个在数据分析和处理中常见的需求。 ... [详细]
  • 在OpenCV 3.1.0中实现SIFT与SURF特征检测
    本文介绍如何在OpenCV 3.1.0版本中通过Python 2.7环境使用SIFT和SURF算法进行图像特征点检测。由于这些高级功能在OpenCV 3.0.0及更高版本中被移至额外的contrib模块,因此需要特别处理才能正常使用。 ... [详细]
  • Jenkins API当前未直接提供获取任务构建队列长度的功能,因此需要通过解析HTML页面来间接实现这一需求。 ... [详细]
  • 本文介绍如何在阿里云环境中利用 Docker 容器化技术部署一个简单的 Flask Web 应用,并确保其可通过互联网访问。内容涵盖 Python 代码编写、Dockerfile 配置、镜像构建及容器运行等步骤。 ... [详细]
  • Java 中的等时日期(int,int)方法,示例 ... [详细]
  • 本文详细介绍了如何使用Python的多进程技术来高效地分块读取超大文件,并将其输出为多个文件。通过这种方式,可以显著提高读取速度和处理效率。 ... [详细]
  • 在C#编程中,数值结果的格式化展示是提高代码可读性和用户体验的重要手段。本文探讨了多种格式化方法和技巧,如使用格式说明符、自定义格式字符串等,以实现对数值结果的精确控制。通过实例演示,展示了如何灵活运用这些技术来满足不同的展示需求。 ... [详细]
  • Java 中 ZonedDateTime 类的天数方法详解及示例代码 ... [详细]
  • 利用Flask框架进行高效Web应用开发
    本文探讨了如何利用Flask框架高效开发Web应用,以满足特定业务需求。具体案例中,一家餐厅希望每天推出不同的特色菜,并通过网站向顾客展示当天的特色菜。此外,还增加了一个介绍页面,在bios路径下详细展示了餐厅主人、厨师和服务员的背景和简介。通过Flask框架的灵活配置和简洁代码,实现了这一功能,提升了用户体验和餐厅的管理水平。 ... [详细]
  • Docker安全策略与管理
    本文探讨了Docker的安全挑战、核心安全特性及其管理策略,旨在帮助读者深入理解Docker安全机制,并提供实用的安全管理建议。 ... [详细]
  • 在尝试加载支持推送通知的iOS应用程序的Ad Hoc构建时,遇到了‘no valid aps-environment entitlement found for application’的错误提示。本文将探讨此错误的原因及多种可能的解决方案。 ... [详细]
author-avatar
聪头丶_505
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有