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)

相关推荐

  • 使用Redis之前5个必须了解的事情有哪些

    技术使用Redis之前5个必须了解的事情有哪些这篇文章给大家介绍使用Redis之前5个必须了解的事情有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。使用Redis开发应用程序是一个很愉快的过程,

    攻略 2021年11月10日
  • 松柏读音,赠从弟其二刘桢这首古诗的读音

    技术松柏读音,赠从弟其二刘桢这首古诗的读音zèng cóng dì qí èr赠从弟·其二
    wèi liú zhēn
    魏晋松柏读音:刘桢
    tíng tíng shān shàng sōng,sè sè gǔ zhōng

    生活 2021年10月21日
  • 奔怎么组词,“奔”字的多音字怎么组词

    技术奔怎么组词,“奔”字的多音字怎么组词奔拼音:【bēn/bèn】其中奔【bèn】的意思和相关组词如下:奔【 bèn】1、直向目的地走去:投奔。直奔工地。他顺着小道直奔那山头。奔向小康。投奔【tóubèn】指前往依靠别人

    生活 2021年10月21日
  • 三角形任意两边之和大于第三边,三角形的三边之间有怎样的关系

    技术三角形任意两边之和大于第三边,三角形的三边之间有怎样的关系1、三角形的三边关系:任意两边之和大于第三边三角形任意两边之和大于第三边,任意两边之差小于第三边。2、设三角形三边为a,b,c则a+b>c,a>c-b,b+c

    生活 2021年10月21日
  • 如何进行Spring框架中的后置增强

    技术如何进行Spring框架中的后置增强这篇文章将为大家详细讲解有关如何进行Spring框架中的后置增强,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。在这一篇中我们看一下

    攻略 2021年12月2日
  • Python光学仿真数值分析怎么求解波动方程绘制波包变化图

    技术Python光学仿真数值分析怎么求解波动方程绘制波包变化图本篇内容介绍了“Python光学仿真数值分析怎么求解波动方程绘制波包变化图”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大

    攻略 2021年10月20日