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

<!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

-- in  views.py

def  get_ali_object():

app_id = 'xxxxxxx' #你的账号APPID

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

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

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

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

(0)

相关推荐

  • python调用支付宝支付接口流程

    项目演示: 一.输入金额 二.跳转到支付宝付款 三.支付成功 四.跳转回自己网站 在使用支付宝接口的前期准备: 1.支付宝公钥 2.应用公钥 3.应用私钥 4.APPID 5.Django 1.11.11 环境 1234均由阿里开放平台生成 如果你不是商户或者你只是想测试,阿里提供了沙箱环境供测试 沙箱环境下的商户账号和用户账号.支付宝app都是沙箱版的,不能用实际账号 这时候我们需要去阿里开放平台去生成一些1234参数 注册网址: https://openhome.alipay.com/pla

  • python实现支付宝转账接口

    由于工作需要使用python开发一个自动转账接口,记录一下开发过程. 首先需要在蚂蚁金服上申请开通开发者账户,有了开发者账户就可以使用沙箱进行开发了. 在开发之前我们需要在沙箱应用中填写密钥,密钥的获取可以使用阿里提供的工具包自动生成. 前期准备工作完成了,接下来是编写代码部分.主要用到了python-alipay-sdk库,使用pip安装即可,如果安装的过程中遇到问题推荐使用Anaconda(crypto这个库安装了我好久没成功,最后换成Anaconda环境了) from datetime i

  • python实现银联支付和支付宝支付接入

    本文实例为大家分享了python银联支付和支付宝支付接入的具体代码,供大家参考,具体内容如下 前置条件:需要安装Python的OpenSSL模块,我使用的版本是16.1.0,可以使用pip install pyopenssl来安装 一.支付宝支付 1. 使用RSA公钥加密系统进行签名和签名验证,需要自己生成一个RSA私钥和对应的一个RSA公钥(在Linux下可以使用ssh-keygen命令来生成),公钥需要上传至支付宝,供支付宝对开发者发送的请求做签名验证使用:而同时支付宝会提供一个RSA公钥给

  • python采用django框架实现支付宝即时到帐接口

    因工作需要研究了支付宝即时到帐接口,并成功应用到网站上,把过程拿出来分享. 即时到帐只是支付宝众多商家服务中的一个,表示客户付款,客户用支付宝付款,支付宝收到款项后,马上通知你,并且此笔款项与交易脱离关系,商家可以马上使用. 即时到帐只对企业客户服务,注册成功企业账号以后,申请签约即时到帐产品,大约3-5个工作日后,签约成功,可以马上进入集成产品阶段. 这个是支付宝提供的接口,有asp,c#,java,php四种语言的,每种语言提供GBK和UTF-8两种方案.另带一份支付宝的文档,这份文档我感觉

  • Python+PIL实现支付宝AR红包

    本文实例为大家分享了Python+PIL处理支付宝AR红包的具体代码,供大家参考,具体内容如下 思路比较简单: 1.对图片进行锐化处理: 2.设(r_h, g_h, b_h)为支付宝遮罩黑条的RGB值,以此为中心,查找半径为Diff_radius的范围内所有的色值: 3.对每一行符合步骤2的像素点个数进行计数,若该数值超过某个临界值(如:图片宽度的一半),将其所在行替换为上一行非遮罩数据: 4.对处理后的图片高斯滤镜. 以下是python代码: from PIL import Image,Ima

  • Python提取支付宝和微信支付二维码的示例代码

    支付宝或者微信支付导出的收款二维码,除了二维码部分,还有很大一块背景图案,例如下面就是微信支付的收款二维码: 有时候我们仅仅只想要图片中间的方形二维码部分,为了提取出中间部分,我们可以使用图片处理软件,但图片处理软件不利于批处理,且学习也需要一定成本.本文将教你使用 Python 的图像处理库 pillow,轻松批量提取图片中间的方形二维码部分. 提取思路 以微信支付收款码图片为例: 分析图片我们可以看到,二维码位于白色背景中,而白色背景又位于绿色背景上.我们以图片左上角为坐标原点,横向为 x

  • python实现支付宝当面付(扫码支付)功能

    本文实例为大家分享了python实现支付宝当面付示的具体代码,供大家参考,具体内容如下 一.配置信息准备 登录蚂蚁金服开放平台:https://open.alipay.com/platform/home.htm 开发资料阅读:https://docs.open.alipay.com/194/106078 创建好应用,配置好密钥等信息后,就可以开发了. 二.开发支付宝支付工具类 1:相关配置信息 # ========支付相关配置信息=========== ALIPAY_INPUT_CHARSET

  • python支付宝支付示例详解

    本文实例为大家分享了python支付宝支付示例代码,供大家参考,具体内容如下 项目演示: 1.输入金额 2.扫码支付: 3.支付完成: 一.注册账号 https://openhome.alipay.com/platform/appDaily.htm?tab=info 二.设置应用公钥 三.代码实现 1.项目结构: 2.把生成的     应用私钥     和    支付宝的公钥       放入keys目录下: 注意: 支付宝公钥 商户私钥 --- 配置商户应用私钥--copy到key目录下 --

  • 熵值法原理及Python实现的示例详解

    目录 1.简单理解 信息熵 2.编制指标 (学术情景应用) 3.python实现 3.1 数据准备 3.2 数据预处理 3.3 熵值.权重计算 3.4 编制综合评价指标 熵值法也称熵权法,是学术研究,及实际应用中的一种常用且有效的编制指标的方法. 1.简单理解 信息熵 机器学习中的决策树算法是对信息熵的一种典型的应用. 在信息论中,使用 熵 (Entropy)来描述随机变量分布的不确定性. 假设对随机变量X,其可能的取值有x1,x2,...,xn .即有n种可能发生的结果.其对应发生的概率依次为

  • Python selenium find_element()示例详解

    selenium有以下定位方式: driver.find_element_by_id('id') driver.find_element_by_xpath('xpath') driver.find_element_by_link_text('link_text') driver.find_element_by_partial_link_text('partial_link_text') driver.find_element_by_name('name') driver.find_element

  • iOS支付宝支付方法详解

    支付宝SDK下载地址:https://doc.open.alipay.com/doc2/detail?treeId=54&articleId=103419&docType=1 支付宝集成 在支付宝集成的过程中,会遇到一些报错,下面就碰到的报错,和大家一起解决. 集成参考官方文档: 导入代码文档:https://doc.open.alipay.com/doc2/detail.htm?spm=0.0.0.0.RiFaVa&treeId=59&articleId=103676&a

  • java微信公众号支付示例详解

    本文实例为大家分享了java微信公众号支付示例代码,供大家参考,具体内容如下 开始之前,先准备好:appid.商家号.商户密匙. 工具类: MD5Util.java package com.yiexpress.core.utils.wechat; import java.security.MessageDigest; /** * MD5工具类 */ public class MD5Util { public final static String MD5(String s) { char hex

  • Python ini配置文件示例详解

    目录 INI介绍 关于configparser INI文件格式 读取配置文件 写入配置文件 总结 INI介绍 INI是英文“初始化”(initialization)的缩写,被用来对操作系统或特定程序初始化或进行参数设置.由节(section). 键(key).值(value)构成.在windows系统中有很多INI文件,例如“System32.ini”和“Win.ini”,相信大家并不陌生.Python 中操作配置文件的模块为configparser,这个模块可以用来解析与Windows上INI

  • 利用Python实现智能合约的示例详解

    目录 智能合约 1. 是什么 2. 使用场景 用Python如何实现 1. 设计智能合约 2. 编写智能合约源代码 3. 编译智能合约 4. 部署智能合约 5. 调用智能合约方法 6. 监控智能合约事件 7. 升级智能合约 智能合约 1. 是什么 智能合约是一种由计算机程序编写的自动化合约,它可以在没有第三方干预的情况下执行交易和契约条款.智能合约使用区块链技术实现,可以实现不同的功能,例如交易.投票.代币发放和数据存储等.智能合约的执行是基于其代码的逻辑,并且在既定条件满足时自动执行.智能合约

  • Python网络爬虫中的同步与异步示例详解

    一.同步与异步 #同步编程(同一时间只能做一件事,做完了才能做下一件事情) <-a_url-><-b_url-><-c_url-> #异步编程 (可以近似的理解成同一时间有多个事情在做,但有先后) <-a_url-> <-b_url-> <-c_url-> <-d_url-> <-e_url-> <-f_url-> <-g_url-> <-h_url-> <--i_ur

  • Python程序包的构建和发布过程示例详解

    关于我 编程界的一名小程序猿,目前在一个创业团队任team lead,技术栈涉及Android.Python.Java和Go,这个也是我们团队的主要技术栈. 联系:hylinux1024@gmail.com 当我们开发了一个开源项目时,就希望把这个项目打包然后发布到 pypi.org 上,别人就可以通过 pip install 的命令进行安装.本文的教程来自于 Python 官方文档 , 如有不正确的地方欢迎评论拍砖. 0x00 创建项目 本文使用到的项目目录为 ➜ packaging-tuto

  • 对python 生成拼接xml报文的示例详解

    最近临时工作要生成xml报名,通过MQ接口发送.简单小程序. 自增长拼成xml报文 Test_001.py # encoding=utf-8 import time orderId = '' s1= "\n" # for ID in range(1,5): item1 = "<item>" + \ "<orderID>" + str(ID) + "</orderID>" + \ "

随机推荐