1. 业务逻辑
准备

  1. 使用沙箱提供的商家环境

    沙箱环境:是支付宝提供给开发者的模拟支付的环境

    沙箱应用:https://docs.open.alipay.com/200/105311

    沙箱账号:https://openhome.alipay.com/platform/appDaily.htm?tab=account

 支付宝开发者文档:

    文档主页:https://openhome.alipay.com/developmentDocument.htm

    产品介绍:https://docs.open.alipay.com/270

    快速接入:https://docs.open.alipay.com/270/105899/

    SDK:https://docs.open.alipay.com/270/106291/

      python对接支付宝SDK:https://github.com/fzlee/alipay/blob/master/README.zh-hans.m

    API列表:https://docs.open.alipay.com/270/105900/
  2.. 生成密钥对
  3. 将公钥加到商品环境中
  4. 将Alipay提供的公钥加入项目中
    支付功能
  5. 根据order_id查询订单对象
  6. 创建alipay对象
  7. 调用方法,生成url
  8. 返回url
    保存支付状态
  9. 根据返回的url请求支付宝
  10. 支付成功后返回商家回调页面--------->会传回很多Alipay传回来的参数,很多明文,防止别人攻击
  11. 返回商家的同时请求后台服务器------>发送这些参数给后台
  12. 接收参数并且验证,成功则创建订单支付对象返回订单号,否则提示支付失败

2.安装包

pip install python-alipay-sdk --upgrade

3.新建一个payments的app应用

python ../../manage.py startapp payments

4.定义一个模型类,继承自BaseModel(创建时间与修改时间)

 class Payment(BaseModel):
"""
支付信息
"""
order = models.ForeignKey(
OrderInfo, on_delete=models.CASCADE, verbose_name='订单')
trade_id = models.CharField(
max_length=100, verbose_name="支付流水号") class Meta:
db_table = 'tb_payment'
verbose_name = '支付信息'
verbose_name_plural = verbose_name

5.配置密钥

  5.1.登录沙箱

    在payments应用中新建keys目录,用来保存秘钥文件。

     将应用私钥文件app_private_key.pem复制到payment/keys目录下。

  5.1.1生成应用的私钥和公钥 

openssl
OpenSSL> genrsa -out app_private_key.pem 2048 # 私钥RSA2
OpenSSL> rsa -in app_private_key.pem -pubout -out app_public_key.pem # 导出公钥 OpenSSL> exit

  5.2 保存应用私钥文件

  5.3 查看公钥

cat app_publict_key.pem
# 将公钥内容复制给支付宝沙箱的<应用私钥>,得到支付宝的<支付宝公钥>

  5.4 保存支付宝公钥

  在payments/keys目录下新建alipay_public_key.pem文件,用于保存支付宝的公钥文件。

  将支付宝的公钥内容复制到alipay_public_key.pem文件中

6.配置路由

GET /orders/(?P<order_id>\d+)/payment/

7.在配置文件中配置ailipay的信息

 # 支付宝支付的配置
ALIPAY_APPID = 'xxxxxxxxxxxxx'
ALIPAY_PRIVATE_KEY_PATH = os.path.join(BASE_DIR, 'apps/payments/alipay/app_private_key.pem')
ALIPAY_PUBLIC_KEY_PATH = os.path.join(BASE_DIR, 'apps/payments/alipay/alipay_public_key.pem')
ALIPAY_DEBUG = True
ALIPAY_SUBJECT = '智学客-订单支付'
ALIPAY_RETURN_URL = 'http://www.xxx.com/pay_success.html'
ALIPAY_GATE = 'https://openapi.alipaydev.com/gateway.do?'

8.定义视图

两个参数:

      order_id: 订单编号

      alipay_uel: 支付宝支付链接

代码如下:

 class AliPayURLView(APIView):
def get(self, request, order_id):
# 1.根据order_id查询订单对象
try:
order_obj = OrderInfo.objects.get(pk=order_id)
except:
raise Exception("订单号无效") # 2.创建alipay对象
alipay = AliPay(
appid=settings.ALIPAY_APPID,
app_notify_url=None,
app_private_key_path=settings.ALIPAY_PRIVATE_KEY_PATH,
alipay_public_key_path=settings.ALIPAY_PUBLIC_KEY_PATH,
debug=settings.ALIPAY_DEBUG
) # 3.调用方法,生成url
# 电脑网站支付,需要跳转到https://openapi.alipay.com/gateway.do? + order_string
order_string = alipay.api_alipay_trade_page_pay(
subject=settings.ALIPAY_SUBJECT,
out_trade_no=order_id, # 订单编号
total_amount=str(order_obj.total_amount), # 支付总金额,类型为Decimal(),不支持序列化,需要强转成str
return_url=settings.ALIPAY_RETURN_URL # 支付成功后的回调地址 )
# 4.返回url
return Response({"alipay_url": settings.ALIPAY_GATE + order_string})

  8.1 在payments/urls.py中定义路由规则 

 url('^orders/(?P<order_id>\d+)/payment/$',views.PaymentView.as_view()),

9.保存支付状态

请求方式:PUT /payment/status/?支付宝参数

参数:trade_id:支付宝流水账号

代码实现:

class OrderStatusView(APIView):
"""验证用户是否登录成功""" def put(self, request):
# 1.接收支付宝返回的数据
data = request.query_params.dict() # 2.验证是否支付成功
# 2.1删除签名,不参与验证
signature = data.pop("sign") # 2.2 创建alipay对象
alipay = AliPay(
appid=settings.ALIPAY_APPID,
app_notify_url=None,
app_private_key_path=settings.ALIPAY_PRIVATE_KEY_PATH,
alipay_public_key_path=settings.ALIPAY_PUBLIC_KEY_PATH,
debug=settings.ALIPAY_DEBUG
) # 2.3 调用verify(字典,签名)
success = alipay.verify(data, signature)
if success:
# 支付成功
'''
{
'total_amount': '11388.00', 支付金额
'auth_app_id': '2016082100304973', 应用编号
'method': 'alipay.trade.page.pay.return',
'trade_no': '2018110722001420410500545016',流水号
'timestamp': '2018-11-07 16:59:20',时间
'app_id': '2016082100304973',应用编号
'out_trade_no': '20181107160224000000001',商城的订单编号
'charset': 'utf-8',编码
'seller_id': '2088102172415825',商家编号
'version': '1.0'版本
}
'''
# 1 获取订单号
order_id = data["out_trade_no"]
# 2 修改订单状态
try:
order_obj = OrderInfo.objects.get(pk=order_id)
except:
raise Exception("订单号无效")
order_obj.status = 2
order_obj.save() # 3.创建订单支付对象
trade_no = data.get('trade_no') # 获取流水号
Payment.objects.create(
order_id=order_id,
trade_no=trade_no
) # 4.响应
return Response({"trade_id": trade_no})
else:
raise Exception("支付失败")

  9.1 定义路由规则 

   url('^payment/status/$',views.PaymentStatusView.as_view()),

Django中对接第三方支付(支付宝)实现支付的流程的更多相关文章

  1. Django day35 redis连接池,redis-list操作,django中使用redis,支付宝支付

    一:redis连接池, 二:redis-list操作, 三:django中使用redis, 四:支付宝支付

  2. django中使用第三方包实现定时任务

    # 转载请留言联系 在做主页静态化的时候,需要定时生成主页HTML,以保持数据的最新. 定时任务可以用第三方包django-crontab来实现. 附上官方文档:https://pypi.org/pr ...

  3. 微信、支付宝App支付-JPay0.0.2发布

    JPay 对微信App支付.支付宝App支付的二次封装,对外提供一个相对简单的接口以及支付结果的回调 GitHub:https://github.com/Javen205/JPay OsChina:h ...

  4. uni-app开发经验分享十八:对接第三方h5

    1.uni-app中对接第三方为了防止跳出app使用了webview <template> <view> <web-view :src="url" @ ...

  5. php支付走过的坑(微信篇 包含h5支付和app支付 注册 秘钥 环境等等配置)

    支付这东西,说容易也容易,说难也难 代码这玩意还比较好说 但是 如果没有demo 直接去看官方文档 十有八九一脸懵逼 今天就整理一下 支付这块走过的坑 涉及 微信h5支付 支付宝h5支付 (api文档 ...

  6. django中的静态文件

    静态文件 1.什么是静态文件 在django中静态文件是指那些图片.css样式.js样式.视频.音频等静态资源. 2.为什么要配置静态文件 这些静态文件往往不需要频繁的进行变动,如果我们将这些静态文件 ...

  7. django中使用事务以及接入支付宝支付功能

    之前一直想记录一下在项目中使用到的事务以及支付宝支付功能,自己一直犯懒没有完,趁今天有点兴致,在这记录一下. 商城项目必备的就是支付订单的功能,所以就会涉及到订单的保存以及支付接口的引入.先来看看订单 ...

  8. Django对接支付宝Alipay支付接口

    最新博客更新见我的个人主页: https://xzajyjs.cn 我们在使用Django构建网站时常需要对接第三方支付平台的支付接口,这里就以支付宝为例(其他平台大同小异),使用支付宝开放平台的沙箱 ...

  9. 对接第三方支付接口-获取http中的返回参数

    这几天对接第三方支付接口,在回调通知里获取返回参数,有一家返回的json格式,请求参数可以从标准输入流中获取. //1.解析参数 , 读取请求内容 BufferedReader br; String ...

随机推荐

  1. hdoj1160【DP】

    现在还很弱,贴一个我bin的结题报告日后写到一定会了加油 说说感觉,读题不读好,然后读完想不出,知道是dp不好好想,先排序一列,再求另一列,dp[ i ]代表长度,那么需要输出整个序列需要路径和一个标 ...

  2. bzoj 1049: [HAOI2006]数字序列【dp+二分+瞎搞】

    第一问明显就是用b[i]=a[i]-i来做最长不下降子序列 然后第二问,对于一对f[i]=f[j]+1的(i,j),中间的数一定要改的,并且是等于b[i]或者b[j],我不会证,然后因为是随机数据,所 ...

  3. IT兄弟连 Java Web教程 经典面试题

    1.什么是B/S结构?什么是C/S结构? B/S是Browser/Server的缩写客户机上只要安装—个浏览器(Browser)加Netscape Navigator或Internet Explore ...

  4. 鸟哥私房菜基础篇:认识与学习BASH习题

    猫宁!!! 参考链接:http://linux.vbird.org/linux_basic/0320bash.php 鸟哥是为中国信息技术发展做出巨大贡献的人. 1-在 Linux 上可以找到哪些 s ...

  5. Android课程设计第二天界面排版

    注意:课程设计只为完成任务,不做细节描述~ 老师叫我们做一个这个样子,然后.. <?xml version="1.0" encoding="utf-8"? ...

  6. 洛谷 P4585 [FJOI2015]火星商店问题

    (勿看,仅作笔记) bzoj权限题... https://www.luogu.org/problemnew/show/P4585 对于特殊商品,直接可持久化trie处理一下即可 剩下的,想了一段时间c ...

  7. archive log full ora-00257

    ############# sample 0 asmcmd show free 37G in archive_log ASMCMD> lsdgState Type Rebal Unbal Sec ...

  8. POJ 1692 Crossed Matchings dp[][] 比较有意思的dp

    http://poj.org/problem?id=1692 这题看完题后就觉得我肯定不会的了,但是题解却很好理解.- - ,做题阴影吗 所以我还是需要多思考. 题目是给定两个数组,要求找出最大匹配数 ...

  9. canvas防画图工具

    <style> body {   background: black;   text-align: center; } #cans {   background: white; } < ...

  10. Android Studio Terminal 不是内部或外部命令,也不是可运行程序或批处理文件

    1.Android Studio Terminal 命令行无效的问题 在Android Studio中自带了命令行终端Terminal,但是我们在输入命令时经常会发现:“XXX”不是内部或外部命令,也 ...