支付宝支付开发-退款

简介: 之前写了一篇支付宝支付开发,现在总结一下支付宝退款的开发。总体上来说,支付宝的退款接口分为即时到账批量有密退款接口(refund_fastpay_by_platform_pwd)和即时到账批量无密退款接口(refund_fastpay_by_platform_nopwd)两种,分别对应前台请求和后台请求。

之前写了一篇支付宝支付开发,现在总结一下支付宝退款的开发。
总体上来说,支付宝的退款接口分为即时到账批量有密退款接口(refund_fastpay_by_platform_pwd)和即时到账批量无密退款接口(refund_fastpay_by_platform_nopwd)两种,分别对应前台请求和后台请求。

通俗说明一下前台请求和后台请求的区别:
前台请求:通过html的form表单方式提交的。
后台请求:直接通过后台交互,利用http请求发送到请求系统。

一、有密退款接口

及时到账有密退款接口比较简单,易于理解,相关字段到支付宝网站查看一般业务流程是:用户发起退款请求->运营人员审批退款请求->同意退款->后台组装退款报文(html)->重定向到支付宝退款页面->运营人员输入密码->支付宝将退款结果异步通知到后台->后台完成剩余后台逻辑。
** DEMO如下: **
用户发起退款后,运营人员打开退款审核页面:

img_3347a877f30894d72884b61ee2b85ceb.png
Paste_Image.png

确认可以退款后,后台组装一个重定向的html到支付宝:

img_04d26f532f374057d5629e7fbf903e1b.png
Paste_Image.png

输入密码后支付宝向notify_url发送退款结果通知。

注:
组装发送到支付宝的html报文样例如下:

<html>
 <head></head>
 <body>
  <form id="alipaysubmit" name="alipaysubmit" action="https://mapi.alipay.com/gateway.do?_input_charset=utf-8" method="post">
   <input type="hidden" name="sign" value="签名值" />
   <input type="hidden" name="_input_charset" value="utf-8" />
   <input type="hidden" name="sign_type" value="MD5" />
   <input type="hidden" name="detail_data" value="201606132100100479^0.01^我要退款" />
   <input type="hidden" name="service" value="refund_fastpay_by_platform_pwd" />
   <input type="hidden" name="notify_url" value="退款通知地址" />
   <input type="hidden" name="seller_user_id" value="值同partner" />
   <input type="hidden" name="partner" value="合作商户ID,需跟支付宝申请" />
   <input type="hidden" name="batch_num" value="1" />
   <input type="hidden" name="batch_no" value="20160613236648747861707090426379" />
   <input type="hidden" name="refund_date" value="2016-06-13 07:57:12" />
   <input type="submit" value="确认" style="display:none;" />
  </form>
  <script>document.forms['alipaysubmit'].submit();</script>
 </body>
</html>

其中的detail_data为单笔数据集,规则见支付宝文档。

img_fa1185127acc396fd156980ae066f2c9.png
Paste_Image.png

需要说明的是:原付款支付宝交易号对应的是支付结果通知时的trade_no字段。

二、无密退款接口

无密退款接口的权限是不开放的,如果你需要的话,需要重新与支付宝签约,有密接口是跟着支付一起的,你具备了支付的接口权限,就能用有密退款接口。
无密退款接口的流程比较简单:用户发起退款->后台组装退款数据->通过http请求到支付宝后台->接收退款结果异步通知->后台完成剩余后台逻辑。
无密接口有几个概念说明如下:

  • 充退:支付宝将退款退到买家支付宝账号后,将钱再退到买家银行卡的过程,也就是这里是两个过程:退到买家支付宝账号,退到买家银行卡。一般我们不关心这个,因为钱退到买家支付宝账号后,钱已经退给买家了,至于能不能从买家的支付宝退到买家的银行卡,一般不关心。
  • 充退结果通知:充退到买家银行卡成功的异步通知。

三、说明(遇到的坑)

  1. 无密接口流程比较简单,一开始就开发了无密接口,结果发现没签约,没权限。

  2. 无密接口请求地址:
    https://mapi.alipay.com/gateway.do?_input_charset=UTF-8
    注意到gateway.do后面的_input_charset的值为UTF-8,我们在请求报文中可能也会有_input_charset这个key,注意其value也应该为UTF-8,不能为小写utf-8,否则验签不过,被坑了一天。

  3. 最后


    img_837fb304f41b27ef4474cca7ef59c5a2.png
    Paste_Image.png
目录
相关文章
|
9月前
|
前端开发 安全 数据安全/隐私保护
支付宝支付流程解读
支付宝支付流程解读
|
XML 移动开发 API
微信支付开发(7) H5支付
关键字:微信支付 微信支付v3 H5支付 wap支付 prepay_id 作者:方倍工作室原文: http://www.cnblogs.com/txw1958/p/wxpayv3_h5.html    本文介绍微信支付下的H5支付实现流程。
2848 0
|
9月前
|
Java 数据安全/隐私保护
支付宝支付功能使用
支付宝支付功能使用
|
11月前
支付收银台初探(2)
支付收银台初探
127 0
|
11月前
|
移动开发 安全 API
支付收银台初探(1)
支付收银台初探
267 0
|
缓存 Java 数据安全/隐私保护
支付宝支付
支付宝支付
|
前端开发 区块链 Python
从 0 到 1 看支付
人类社会自从有了分工,就有了交换,而有了交换,也就有了支付,交换可以说是支付最古老的表现形态
199 0
从 0 到 1 看支付
手机网站支付之对账篇
场景介绍 商户接入了手机网站支付后,想通过接口下载指定日期(当天除外)的业务明细账单文件,并结合自身业务系统,从而实现对账功能,为此,我们提供了查询对账单下载地址接口作为辅助,本接口支持appid所对应PID下所有的交易记录对账,下面小编就为您讲解简单的接入调用流程: 接口调用流程    1.商户系统调用查询对账单下载地址接口alipay.data.dataservice.bill.downloadurl.query,传入指定日期,获得该日期账单文件的下载地址。
846 0