博客
关于我
python-aliyay-sdk中verify函数一直返回false的解决办法
阅读量:639 次
发布时间:2019-03-14

本文共 1800 字,大约阅读时间需要 6 分钟。

最近flask项目在使用支付宝沙箱支付时出现了以下问题:

def verify(self, data, signature):    if "sign_type" in data:        sign_type = data.pop("sign_type")        if sign_type != self._sign_type:            raise AliPayException(None, "Unknown sign type: {}".format(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)

verify函数接收两个变量,其中data是支付宝发送过的除了sign(签名信息)以外的其他信息,signature是支付宝发送过来的签名信息,verify函数会更具data信息来生成一个前面信息和支付宝的signature做比较,如果相等则返回true,不相等返回false。

在运行过程中该函数的返回结果一直是false,verify函数中把sign_type参数给剔除掉了。
解决办法对verify函数进行以下修改:

def verify(self, data, signature):        # if "sign_type" in data:        #     sign_type = data.pop("sign_type")        #     if sign_type != self._sign_type:        #         raise AliPayException(None, "Unknown sign type: {}".format(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)

支付宝请求的网址如下:GET /payComplete.html?charset=utf-8&out_trade_no=25&method=alipay.trade.wap.pay.return&total_amount=5000.00&sign=TqQXWB0glO95D3usCbvES38L%2BZn4XjG8mR%2FhoTMmbR8CU0GJePMFTcN%2Flh%2FoaebCzZcQytmO2QV1DRdyJJhaVx618T0t0WlV4V%2F4ItVZbWt8VfUOJUD8Mvv5c1qmPwIo05FaoIa9crF6qX8SWKweSiuaU7bRFbmwGfIYGE1Ga00f7HpqH3BOUs6eT4KkmUq5mVVLIOPftsPyQDF9zs%2FYlcnHGsBb4RRMS1uRGASNuoax6VrPpOKC%2BpsMqAoROB5SPC2FZTBEKd48rEZ6MaGA9zdTnbKGyWajJ2lmZZwfjbKpgsDkCFgD%2F2VL4upxfDwMoqRv%2Fbn3F%2F4sDD%2FUCpUMPg%3D%3D&trade_no=2020090722001475820501161374&auth_app_id=2016101900722989&version=1.0&app_id=2016101900722989&sign_type=RSA2&seller_id=2088102180276586&timestamp=2020-09-07+11%3A22%3A56 HTTP/1.1" 200 -

如果有不对的地方希望大家多多指教!

转载地址:http://eihoz.baihongyu.com/

你可能感兴趣的文章
mysql的sql_mode参数
查看>>
MySQL的sql_mode模式说明及设置
查看>>
mysql的sql执行计划详解
查看>>
mysql的sql语句基本练习
查看>>
Mysql的timestamp(时间戳)详解以及2038问题的解决方案
查看>>
mysql的util类怎么写_自己写的mysql类
查看>>
MySQL的xml中对大于,小于,等于的处理转换
查看>>
Mysql的两种存储引擎详细分析及区别(全)
查看>>
mysql的临时表简介
查看>>
MySQL的主从复制云栖社区_mysql 主从复制配置
查看>>
mysql的优化策略有哪些
查看>>
MySQL的使用
查看>>
mysql的全文检索的方法
查看>>
mysql的函数DATE_ADD()
查看>>
mysql的函数操作
查看>>
Mysql的分表设计方法 (水平分表和垂直分表)
查看>>
mysql的分页查询limit关键字
查看>>
MySql的创建数据表、约束、外键约束的创建修改删除、级联操作
查看>>
MySQL的四大隔离级别,你都知道哪些?
查看>>
MySQL的四种事务隔离级别
查看>>