用python模拟微信支付,利用Python开发微信支付的注意事项

前言

微信支付是由微信及财付通联合推出的移动支付创新产品。如今,随着微信支付的全面开放,相关需求也越来越多,很多开发人员进行微信支付开发及商家申请微信支付时,面临着诸多疑惑。

要想开发顺利进行,首先要对业务流程有个清晰的认识。这里以微信公众号支付为例,因此也借用微信支付官方文档中的业务流程图:

9b7ef1d560fffa088d12c273e35762ff.png

接下来来关注几个开发过程中的关键点,包括:

1、生成商户订单与调用统一下单 API

2、微信服务器交互的数据格式

3、公众号支付下网页内通过 JS-API 调起支付

4、异步通知商户支付结果(回调)

一、生成商户订单与调用统一下单 API

这对应业务流程中的第 4 和 第 5 步,商户后台首先为用户生成订单,然后调用微信的【统一下单】接口向微信支付系统提交订单。这里有一个关键点就是签名的生成。

简单来讲分为以下几个步骤:

1、将所有有效参数以“k=v”的形式进行拼接,有效参数是指非空参数,也就是说如果参数为空,则不参与签名;

2、将所有的“k=v”对用“&”连接,得到“k1=v1&k2=v2&k3=v3”这样的字符串;

3、将微信支付 API 密钥 拼接在最后,如“k1=v1&k2=v2&k3=v3&key=secret”;

4、对整体进行 MD5 运算,即得到签名。

这种签名方法有一个高大上的名字叫做 HMAC(Hash-based Message Authentication Code,基于哈希的消息码)。基于此思路,可以实现如下签名方法:

def gen_sign(params, key):

"""

签名生成函数

:param params: 参数,dict 对象

:param key: API 密钥

:return: sign string

"""

param_list = [] for k in sorted(params.keys()):

v = params.get(k)

if not v:

# 参数的值为空不参与签名

continue

param_list.append('{0}={1}'.format(k, v))

# 在最后拼接 key

param_list.append('key={}'.format(key))

# 用 & 连接各 k-v 对,然后对字符串进行 MD5 运算

return md5('&'.join(param_list).encode('utf8')).hexdigest()

参与签名的参数中有一个随机字符串,在 Python 中有很多方法,当然也可以利用uuid库来生成:

def gen_nonce_str():

"""

生成随机字符串,有效字符a-zA-Z0-9

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Python模拟微信支付,您需要使用以下步骤: 1.安装WeChat SDK:使用pip install wechat-sdk在Python环境中安装WeChat SDK。 2.获取微信API密钥和商户号:在微信支付平台上注册账号并获取API密钥和商户号。 3.创建支付请求:构建一个JSON请求,包含交易金额、商户ID、订单ID和其他必要信息。 4.签名请求:将请求转换为字符串格式(可以使用JSON.dumps()函数),并将其与API密钥一起使用MD5哈希进行签名。 5.发起请求:将签名请求作为POST请求发送到微信支付平台。 6.检查响应:收到响应后,您可以检查其状态代码以确保交易已成功。您还可以从响应中提取交易ID,以便以后跟踪交易。 以下是一个简单的Python代码示例,用于模拟微信支付: ```python import json import hashlib import requests # 设置API密钥和商户号 api_key = 'your_api_key' mch_id = 'your_merchant_id' # 构建支付请求 payment_request = { 'appid': 'wx0000000000000000', 'mch_id': mch_id, 'nonce_str': '1234567890', 'out_trade_no': '20180605000001', 'total_fee': 10000, 'spbill_create_ip': '127.0.0.1', 'notify_url': 'http://example.com/notify', 'trade_type': 'APP' } # 签名请求 payment_request_str = json.dumps(payment_request, separators=(',', ':')) payment_request_str += '&key=' + api_key payment_signature = hashlib.md5(payment_request_str.encode('utf-8')).hexdigest().upper() payment_request['sign'] = payment_signature # 发起请求 response = requests.post('https://api.mch.weixin.qq.com/pay/unifiedorder', data=payment_request) # 检查响应 if response.status_code == 200: response_data = xmltodict.parse(response.text) if response_data['return_code'] == 'SUCCESS' and response_data['result_code'] == 'SUCCESS': transaction_id = response_data['transaction_id'] # 记录交易ID并标记付款成功 else: # 处理交易失败的情况 else: # 处理请求失败的情况 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值