三分钟python搭建支付宝三方支付

作者:楼下安同学 时间:2022-02-03 22:58:42 

为什么使用三方支付?

  再没有三方支付平台之前,用户发起支付请求的时候,用户要去和银行签约(转账),特别的不方便,为了解决这些问题,就有了三方支付,三方平台去完成签约,给用户节省时间。

支付宝支付的流程

  商户拿到支付宝的公钥、自己的私钥(私钥加密、公钥解密),用私钥请求支付宝,支付宝解密、验签、进行支付处理,支付宝将处理的返回值传给商户,当支付成功后,返还给商户订单号、金额、时间戳等消息,支付失败后同样给商户反馈结果。

配置流程

1、获取APPID

支付宝开放平台:https://open.alipay.com/

登录支付宝开放平台–>点击控制台

三分钟python搭建支付宝三方支付

点击沙箱(复制APPID)

三分钟python搭建支付宝三方支付

2、在线生成密钥

点击文档,找到开发助手,点击在线加密。

三分钟python搭建支付宝三方支付

获取私钥

三分钟python搭建支付宝三方支付

3、获取公钥

点击应用公钥

三分钟python搭建支付宝三方支付

生成公钥

三分钟python搭建支付宝三方支付

现在已经拿到了需要的公钥。

python项目中集成支付宝

构建支付类


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 base64 import decodebytes, encodebytes
import json

class AliPay:
   """
   支付宝支付接口(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",
       }

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"))
       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)

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))
       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:
           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)

实例化类


def init_alipay():
   # 初始化Alipay
   alipay = AliPay(
       appid="appid",
       app_notify_url="回调地址",
       return_url="回调地址",
       app_private_key_path="私钥相对路径",
       alipay_public_key_path="公钥相对路径",
       debug=True  # 支付环境
   )
   return alipay

API


async def get(self):

alipay = init_alipay()
   # 传一个标题  订单号  订单价格
   params = alipay.direct_pay("三方广告平台", order_no, money)
   url = f"https://openapi.alipaydev.com/gateway.do?{params}"
   return self.write(ret_json(url))

# 构建一个回调地址,用于支付成功后回调,在回调地址中可以获取订单号(out_trade_no)、金额(total_amount)、时间戳(timestamp),然后进行处理业务逻辑。

来源:https://blog.csdn.net/weixin_45394086/article/details/121843483

标签:python,支付宝,支付
0
投稿

猜你喜欢

  • python使用ctypes调用扩展模块的实例方法

    2021-11-01 22:22:58
  • 解决iframe的frameborder在chrome/ff/ie下的差异

    2023-08-09 00:23:24
  • Python 提速器numba

    2021-04-27 21:14:06
  • 动态给表添加删除字段并同时修改它的插入更新存储过程

    2011-12-01 10:18:28
  • Python关于print的操作(倒计时、转圈显示、进度条)

    2022-08-19 07:26:58
  • 详解Python常用标准库之os模块与shutil模块

    2023-06-13 04:19:20
  • Python time模块时间获取和转换方法

    2022-06-07 11:14:30
  • IE与Firefox的CSS兼容大全

    2008-01-31 15:36:00
  • php判断输入不超过mysql的varchar字段的长度范围

    2023-11-14 12:02:10
  • python函数中return后的语句一定不会执行吗?

    2022-03-25 04:06:44
  • 用ASP显示ACCESS数据库的GIF图象

    2008-11-16 18:09:00
  • 把JS与CSS写在同一个文件里

    2007-12-16 15:29:00
  • [译]艺术和设计的差异 (1)

    2009-09-25 12:38:00
  • Pytorch实现将label变成one hot编码的两种方式

    2021-08-26 08:45:00
  • python对象转字典的两种实现方式示例

    2023-12-06 15:47:05
  • windows下Python安装、使用教程和Notepad++的使用教程

    2023-04-21 09:31:39
  • 搭建 Selenium+Python开发环境详细步骤

    2022-10-12 17:34:02
  • Django重装mysql后启动报错:No module named ‘MySQLdb’的解决方法

    2023-02-01 07:31:31
  • python中hashlib模块用法示例

    2023-03-20 12:20:13
  • 基于Python实现对比Exce的工具

    2022-12-04 17:44:44
  • asp之家 网络编程 m.aspxhome.com