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

python支付宝支付示例详解

这篇文章主要为大家详细介绍了python支付宝支付示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

项目演示:

1、输入金额

2、扫码支付:

3、支付完成:

一、注册账号

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

二、设置应用公钥

三、代码实现

1、项目结构:

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

注意:

支付宝公钥

商户私钥

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

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

但是要做修改:

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端支付接口) 

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




 
 
 


 
 {% csrf_token %}
 
 
 


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

git项目地址

 (1)、修改APPID

-- 这是你账号的APPID       

-- in  views.py

def  get_ali_object():

 app_id = 'xxxxxxx' #你的账号APPID  

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

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

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

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


推荐阅读
  • 本文内容皆为作者原创,如需转载,请注明出处:https:www.cnblogs.comxuexianqip13045462.html1.自定义分页器的拷贝及使用当我们需要使用 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • Django学习笔记之djangodebugtoolbar使用指南
    介绍django-debug-toolbar是一组可配置的面板,可显示有关当前请求响应的各种调试信息,并在单击时显示有关面板内容的更多详细信息。github地址文档地址安装配置1. ... [详细]
  • 原文:http:blog.linjunhalida.comblogpjaxgithub:https:github.comdefunktjquery-pjax ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • 使用正则表达式爬取36Kr网站首页新闻的操作步骤和代码示例
    本文介绍了使用正则表达式来爬取36Kr网站首页所有新闻的操作步骤和代码示例。通过访问网站、查找关键词、编写代码等步骤,可以获取到网站首页的新闻数据。代码示例使用Python编写,并使用正则表达式来提取所需的数据。详细的操作步骤和代码示例可以参考本文内容。 ... [详细]
  • 在Android中解析Gson解析json数据是很方便快捷的,可以直接将json数据解析成java对象或者集合。使用Gson解析json成对象时,默认将json里对应字段的值解析到java对象里对应字段的属性里面。然而,当我们自己定义的java对象里的属性名与json里的字段名不一样时,我们可以使用@SerializedName注解来将对象里的属性跟json里字段对应值匹配起来。本文介绍了使用@SerializedName注解解析json数据的方法,并给出了具体的使用示例。 ... [详细]
  • HTML5网页模板怎么加百度统计?
    本文介绍了如何在HTML5网页模板中加入百度统计,并对模板文件、css样式表、js插件库等内容进行了说明。同时还解答了关于HTML5网页模板的使用方法、表单提交、域名和空间的问题,并介绍了如何使用Visual Studio 2010创建HTML5模板。此外,还提到了使用Jquery编写美好的HTML5前端框架模板的方法,以及制作企业HTML5网站模板和支持HTML5的CMS。 ... [详细]
  • 从零基础到精通的前台学习路线
    随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
  • 1、DashAPI文档Dash是一个API文档浏览器,使用户可以使用离线功能即时搜索无数API。程序员使用Dash可访问iOS,MacOS, ... [详细]
  • 入门Java需熟练掌握哪些技术呢?
    Java工程师无疑是当下令人艳羡的工作之一,因此,每年都有大批大批的朋友想要报名Java工程师学习Java也就不奇怪了。那么入门Java掌握哪些技术能力 ... [详细]
  • 公司有3个后端,一个前端(我),我属于初级水平吧,开发流程:前端切页面、写页面交互,然后把页面给后端(JAVA),后端“套页面”(Velocity模板),然后前端在模板上再进行微调。显然 ... [详细]
author-avatar
三砖先生
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有