Python项目实战之如何使用Django框架实现支付宝付款

技术Python项目实战之如何使用Django框架实现支付宝付款这篇文章主要介绍“Python项目实战之如何使用Django框架实现支付宝付款”,在日常操作中,相信很多人在Python项目实战之如何使用Django框架实

本文主要介绍“Python项目实战中如何使用Django框架实现支付宝支付”。在日常操作中,相信很多人对于Python项目实战中如何使用Django框架实现支付宝支付都有疑问。边肖查阅了各种资料,整理出简单易用的操作方法,希望能帮助大家解答“Python项目实战中如何使用Django框架实现支付宝支付”的疑惑。接下来,请和边肖一起学习!

一、前言

我相信当你支付的时候,微信和支付宝绝对是首选。今天心血来潮,边肖给大家带来了一个非常有趣的项目,那就是利用Python web框架Django实现支付宝支付。废话不多说,我们来看看如何实现。

二、建立django应用

让我们构建一个Django项目,然后在其中创建一个应用程序,如图所示:

Python项目实战之如何使用Django框架实现支付宝付款

三、配置并启动

Python项目实战之如何使用Django框架实现支付宝付款

Python项目实战之如何使用Django框架实现支付宝付款

然后我们设置URL文件的内容,如图所示:

Python项目实战之如何使用Django框架实现支付宝付款

然后在子应用程序中创建一个urls.py文件。当然,也可以在项目中的urls.py文件中直接编写一些视图函数。最后,我们编写view函数并将其添加到urls.py文件中,如图所示:

Python项目实战之如何使用Django框架实现支付宝付款

Python项目实战之如何使用Django框架实现支付宝付款

最后,我们需要提交更改,打开这个项目的manage.py文件所在的目录,打开cmd,并输入以下命令:

python manage.py迁移

现在让我们在本地或这个目录中运行这个项目,如下所示:

python manage.py runserver

Python项目实战之如何使用Django框架实现支付宝付款

输出显示这个子应用程序已经启动并返回结果。或者我们可以直接在创建的项目根目录下运行并启动Django应用程序,而不需要经过子应用程序。首先,在支付目录中创建新的view.py文件,然后将其添加到该目录中的urls.py文件,如下所示:

Python项目实战之如何使用Django框架实现支付宝付款

Python项目实战之如何使用Django框架实现支付宝付款

运行以下图片:

Python项目实战之如何使用Django框架实现支付宝付款

四、登录支付宝并生成rsa密钥

首先,登录我们要收款的支付宝。地址:

https://auth.alipay.com/login/ant_sso_index.htm?goto=https://openhome .支付宝.com/platform/appDaily.htm?tab=信息

然后登录,如图:

0210521/332/381192.jpg" alt="Python项目实战之如何使用Django框架实现支付宝付款">

然后点击RSA2(SHA256)后面的设置,点击公钥并下载支付宝密钥生成器或者openssl来生成密钥,这里我选择支付宝密钥生成器,如图:

Python项目实战之如何使用Django框架实现支付宝付款

然后点击它之后跳转到下载界面下载,如图:

Python项目实战之如何使用Django框架实现支付宝付款

下载好后打开该工具,选择好密钥长度和密钥格式并生成密钥,如图:

Python项目实战之如何使用Django框架实现支付宝付款

然后进入公私钥的目录,将这个复制到我们的Django项目的子应用目录中,并重命名,等下用的着,如图:

Python项目实战之如何使用Django框架实现支付宝付款

Python项目实战之如何使用Django框架实现支付宝付款

紧接着我们进入自己的开发者中心控制台,地址:

https://open.alipay.com/platform/developerIndex.htm

然后我们去创建一个应用,如图:

Python项目实战之如何使用Django框架实现支付宝付款

按照要求如实填写即可。然后我们来设置它的接口加密方式,如图:

Python项目实战之如何使用Django框架实现支付宝付款

Python项目实战之如何使用Django框架实现支付宝付款

验证好了之后填写刚刚生成的应用公钥,如图:

Python项目实战之如何使用Django框架实现支付宝付款

此时会出现应用公钥和支付宝公钥,将支付宝公钥保存起来,如图:

Python项目实战之如何使用Django框架实现支付宝付款

然后我们将产生的额应用公私钥和支付宝公钥保存为下列内容形式的文件,如图:

Python项目实战之如何使用Django框架实现支付宝付款

Python项目实战之如何使用Django框架实现支付宝付款

Python项目实战之如何使用Django框架实现支付宝付款

将这三个文件都保存在rsakey这个文件夹中。现在准备工作都做好了,下面开始编写支付宝支付接口。

注:项目审核通过后才可以使用密钥调用支付宝接口噢!

四、PC端支付宝支付接口

这里我们使用一个类将它封装起来,如下:

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)

为了便于调用,我们将这个Python文件放在子应用的目录中,命名为pay.py。

五、编写前端页面

我们通过前端的商品的名称和价格来生成对应的商品信息并发起付款请求,如下:

index.html(商品主页)

<!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>      <style>   table,table tr th, table tr td { border:1px solid #0094ff; }         table { width:300px; min-height: 25px; line-height: 25px; text-align: center; border-collapse: collapse; padding:2px;}            a{             text-decoration: none;         } </style> </head> <body>     <h2>欢迎来到购物商场</h2>     <table border="1">     <thead>商品目录</thead>     <tr>         <td>商品名</td>         <td>商品单价</td>         <td>商品数量</td>         <td>是否购买</td>     </tr>     <tr>         <td>梨子</td>         <td>0.1</td>         <td>1</td>         <td><a href="{% url 'dingdan' %}">购买</a></td>     </table> </body> </html>

show.html(支付结果显示页)

<!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title> </head> <body>     <h2>支付结果:{{msg}}</h2> </body> </html>

六、编写视图函数处理渲染

from django.shortcuts import render,redirect from django.http import HttpResponse,JsonResponse from .pay import AliPay import uuid from urllib.parse import parse_qs # Create your views here. def index(request):      return render(request,'index.html')  def dingdan(request):     # 实例化AliPay     alipay = AliPay(         appid="自己的APPID",         app_notify_url='http://127.0.0.1:8000/paypay/check/',#支付宝会向这个地址发送post请求         return_url='http://127.0.0.1:8000/paypay/show/',#支付宝会向这个地址发送get请求         app_private_key_path=r'C:\Users\Administrator\Desktop\pay\paypay\rsakey\private2048.txt',  # 应用私钥         alipay_public_key_path=r'C:\Users\Administrator\Desktop\pay\paypay\rsakey\paypublic.txt',  # 支付宝公钥         debug=True,  # 默认是False     )     # 定义请求地址传入的参数     res=alipay.direct_pay(         subject='梨子',  # 商品描述         out_trade_no=str(uuid.uuid4()),  # 订单号         total_amount='0.1',  # 交易金额(单位是元,保留两位小数)     )     #生成跳转到支付宝支付页面的url     url='https://openapi.alipaydev.com/gateway.do?{0}'.format(res)     return redirect(url)    def show(request):     if request.method == 'GET':         alipay = AliPay(             appid="自己的APPID",               app_notify_url='http://127.0.0.1:8000/paypay/check/',             return_url='http://127.0.0.1:8000/paypay/show/',             app_private_key_path=r'C:\Users\Administrator\Desktop\pay\paypay\rsakey\private2048.txt',  # 应用私钥             alipay_public_key_path=r'C:\Users\Administrator\Desktop\pay\paypay\rsakey\paypublic.txt',  # 支付宝公钥             debug=True,  # 默认是False         )         param=request.GET.dict()  # 获取请求携带的参数并转换成字典类型         sign=param.pop('sign', None)  # 获取sign的值         # 对sign参数进行验证         statu = alipay.verify(param,sign)         if statu:             return render(request, 'show.html', {'msg': '支付成功'})         else:             return render(request, 'show.html', {'msg': '支付失败'})     else:         return render(request, 'show.html', {'msg': '只支持GET请求,不支持其它请求'})  def check(request):     if request.method=='POST':         alipay=AliPay(appid="自己的APPID",             app_notify_url='http://127.0.0.1:8000/paypay/check/',  # 支付宝会向这个地址发送post请求             return_url='http://127.0.0.1:8000/show_msg/',  # 支付宝会向这个地址发送get请求             app_private_key_path=r'C:\Users\Administrator\Desktop\pay\paypay\rsakey\private2048.txt',  # 应用私钥             alipay_public_key_path=r'C:\Users\Administrator\Desktop\pay\paypay\rsakey\paypublic.txt',  # 支付宝公钥             debug=True,         )         body=request.body.decode('utf-8')  # 转成字符串         post_data = parse_qs(body)  # 根据&符号分割         post_dict = {}         for k, v in post_data.items():             post_dict[k] = v[0]         sign = post_dict.pop('sign', None)         status = alipay.verify(post_dict, sign)         if status:  # 支付成功             return HttpResponse('支付成功')         else:             return HttpResponse('支付失败')     else:         return HttpResponse('只支持POST请求')

七、添加路由函数到url规则中

from django.urls import path from . import views urlpatterns=[   path('',views.index,name='index'),   path('dingdan/',views.dingdan,name='dingdan'),   path('show/',views.show,name='show'),   path('check/',views.check,name='check'), ]

八、运行项目

所有准备工作都做好了,我们赶紧来试着运行下项目吧,如下:

Python项目实战之如何使用Django框架实现支付宝付款

可以看到我们购买商品后链接成功跳转到支付界面。

到此,关于“Python项目实战之如何使用Django框架实现支付宝付款”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/36819.html

(0)

相关推荐

  • rocketmq 报什么错要重推(rocketmq能存储多少个topic)

    技术RocketMQ架构上主要分为几个部分这篇文章主要介绍RocketMQ架构上主要分为几个部分,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!技术架构RocketMQ架构上主要分为四部分,如上图所

    攻略 2021年12月18日
  • 香辣鱼片的家常做法,香辣鱼条的简单做法是什么

    技术香辣鱼片的家常做法,香辣鱼条的简单做法是什么我是刘涛美食,感谢邀请香辣鱼片的家常做法。到超市去买那种袋装的龙利鱼,又没有刺,容易新手操作,而且那种鱼的口感特别嫩,又没有什么腥味。我来说下最简单又实用的操作方法:
    1:

    生活 2021年10月26日
  • redis 如何获取所有的key(redisscan有什么问题)

    技术redis中如何使用scan这篇文章主要为大家展示了“redis中如何使用scan”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“redis中如何使用scan”这篇文章吧。

    攻略 2021年12月16日
  • Nginx怎么实现限流

    技术Nginx怎么实现限流这篇文章主要为大家展示了“Nginx怎么实现限流”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Nginx怎么实现限流”这篇文章吧。Nginx 限流N

    攻略 2021年11月24日
  • 摩拜单车退押金怎么退,微信上的摩拜押金怎么退款

    技术摩拜单车退押金怎么退,微信上的摩拜押金怎么退款微信摩拜单车使用步骤 你只要打开手机摩拜单车退押金怎么退,摩拜单车将出现在“微信钱包”页面的第三方服务“九宫格”中, 与微信此前接入的“滴滴出行”、“美团外卖”、“京东优

    2021年10月30日
  • ibatis怎么多条件查询(ibatis优点)

    技术iBATIS发展方向的四个方面分别是什么这期内容当中小编将会给大家带来有关iBATIS发展方向的四个方面分别是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。iBATIS发展方向

    攻略 2021年12月19日