本文实例为大家分享了python实现支付宝当面付示的具体代码,供大家参考,具体内容如下
一、配置信息准备
登录蚂蚁金服开放平台:https://open.alipay.com/platform/home.htm
开发资料阅读:https://docs.open.alipay.com/194/106078
创建好应用,配置好密钥等信息后,就可以开发了。
二、开发支付宝支付工具类
1:相关配置信息
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
# ========支付相关配置信息===========
ALIPAY_INPUT_CHARSET = 'utf-8'
# 商户ID,以2088开头的16位纯数字
ALIPAY_PARTNER = '2088************'
# 服务商支付宝账号
ALIPAY_SELLER_EMAIL = ''
# 支付结果回调地址
ALIPAY_NOTIFY_URL = "商家后台回调接口地址"
# 访问模式,根据自己的服务器是否支持ssl访问,若支持请选择https;若不支持请选择http
ALIPAY_TRANSPORT = 'https'
#签名加密方式
SIGN_TYPE = "SHA-1"
#应用id
APP_ID = '************'
#下单api
precreate_GATEWAY = <a href = "https://openapi.alipay.com/gateway.do?" >https: / / openapi.alipay.com / gateway.do?< / a>
|
2.三个辅助函数:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
#1:生成下单请求参数字符串
def make_payment_request( self ,params_dict):
"""
构造支付请求参数
:param params_dict:
:return:
"""
query_str = self .params_to_query(params_dict,) # 拼接参数字符串
sign = self .make_sign(query_str) # 生成签名
sign = urllib.quote(sign, safe = '') #解决中文参数编码问题
res = "%s&sign=%s" % (query_str, sign)
return res
def params_to_query( self ,params):
"""
生成需要签名的字符串
:param params:
:return:
"""
"""
:param params:
:return:
"""
query = ""
dict_items = {}
for key, value in params.items():
if isinstance (value, dict ) = = True :
dict_items[key] = value
params[key] = "%s"
all_str = ''
for key in sorted (params.keys()): #把参数按key值排序:这是支付宝下单请求的参数格式规定
all_str = all_str + '%s=%s&' % (key, params[key])
all_str = all_str.rstrip( '&' )
biz_content_dict = dict_items[ 'biz_content' ]
content_str = ''
for key in sorted (biz_content_dict.keys()):
if isinstance (biz_content_dict[key], basestring ) = = True :
content_str = content_str + '"%s":"%s",' % (key, biz_content_dict[key])
else :
content_str = content_str + '"%s":%s,' % (key, biz_content_dict[key])
content_str = content_str.rstrip( ',' )
content_str = '{' + content_str + '}'
query = all_str % content_str
return query
def make_sign( self ,para_str):
"""
生成签名
:param message:
:return:
"""
private_key = OpenSSL.crypto.load_privatekey(OpenSSL.crypto.FILETYPE_PEM, open (
'./路径/private_key.txt' ).read()) #把私钥存到一个文件里,加载出来【尝试过用rsa模块的方法加载私钥字符串,会报格式错误。查看源码得知,需要从文件流加载】
import sys
reload (sys)
sys.setdefaultencoding( 'utf-8' ) #这三句:解决签名方法编码报错
sign = base64.encodestring(OpenSSL.crypto.sign(private_key, para_str, 'sha256' ))
return sign
|
3.下单
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
#获取二维码url
def getAlipayUrl( self ,orderid,goodsName,goodsPrice, * * kwargs):
# 构建公共参数
params = {}
params[ 'method' ] = 'alipay.trade.precreate'
params[ 'version' ] = '1.0'
params[ 'app_id' ] = self .APP_ID
params[ 'timestamp' ] = datetime.now().strftime( '%Y-%m-%d %H:%M:%S' )
params[ 'charset' ] = self .ALIPAY_INPUT_CHARSET
params[ 'notify_url' ] = self .ALIPAY_NOTIFY_URL
params[ 'sign_type' ] = 'RSA2'
# 构建订单参数
biz_content = {}
biz_content[ 'out_trade_no' ] = orderid # 订单号
biz_content[ 'subject' ] = goodsName #商品名
biz_content[ 'total_amount' ] = goodsPrice # 价格
params[ 'biz_content' ] = biz_content
#由参数,生成签名,并且拼接得到下单参数字符串
encode_params = self .make_payment_request(params)
#下单
url = self .precreate_GATEWAY + encode_params
response = requests.get(url)
#提取下单响应
body = response.text
#解析下单响应json字符串
body_dict = json.loads(body)
return_msg = body_dict[ 'alipay_trade_precreate_response' ][ 'msg' ]
if return_msg = = "Success" :
code_url = body_dict[ 'alipay_trade_precreate_response' ][ 'qr_code' ]
return code_url
else :
print "fail msg=============" + return_msg
|
三、在controller端,接收客户端传过来的订单号、商品名、商品价格,调用支付工具类,得到二维码链接,根据链接生成二维码,传给客户端。
(此处同微信扫码支付模式二)
四、在controller端,编写支付结果回调函数
1
2
3
4
5
6
|
def aliQRCodeNotify( self , request, * args, * * kwargs):
out_trade_no = kwargs.get( "out_trade_no" )
trade_status = kwargs.get( "trade_status" )
#根据trade_status,判断交易结果:交易成功 or 交易关闭
#根据out_trade_no 更新订单记录信息
|
五、客户端轮询
同微信扫码支付模式二客户端轮询思路。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/ygj0930/p/7680348.html