支付宝支付开发-退款

简介: 之前写了一篇支付宝支付开发,现在总结一下支付宝退款的开发。总体上来说,支付宝的退款接口分为即时到账批量有密退款接口(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
目录
相关文章
|
前端开发 安全 数据安全/隐私保护
支付宝支付流程解读
支付宝支付流程解读
|
XML 移动开发 API
微信支付开发(7) H5支付
关键字:微信支付 微信支付v3 H5支付 wap支付 prepay_id 作者:方倍工作室原文: http://www.cnblogs.com/txw1958/p/wxpayv3_h5.html    本文介绍微信支付下的H5支付实现流程。
3440 1
支付系统43-----支付宝支付-统一收单退款,全额退款这里可以发起一笔或者两笔订单
支付系统43-----支付宝支付-统一收单退款,全额退款这里可以发起一笔或者两笔订单
|
8月前
|
消息中间件 Java 测试技术
支付宝支付
支付宝支付
207 1
|
Java 数据安全/隐私保护
支付宝支付功能使用
支付宝支付功能使用
|
移动开发 安全 API
支付收银台初探(1)
支付收银台初探
487 0
|
安全 PHP 开发工具
支付宝支付改版了,你知道吗?
支付宝支付改版了,你知道吗?
255 0
支付宝支付改版了,你知道吗?
手机网站支付之对账篇
场景介绍 商户接入了手机网站支付后,想通过接口下载指定日期(当天除外)的业务明细账单文件,并结合自身业务系统,从而实现对账功能,为此,我们提供了查询对账单下载地址接口作为辅助,本接口支持appid所对应PID下所有的交易记录对账,下面小编就为您讲解简单的接入调用流程: 接口调用流程    1.商户系统调用查询对账单下载地址接口alipay.data.dataservice.bill.downloadurl.query,传入指定日期,获得该日期账单文件的下载地址。
917 12
|
XML 前端开发 API
微信小程序支付及退款流程详解
原文:微信小程序支付及退款流程详解 微信小程序的支付和退款流程 近期在做微信小程序时,涉及到了小程序的支付和退款流程,所以也大概的将这方面的东西看了一个遍,就在这篇博客里总结一下。 首先说明一下,微信小程序支付的主要逻辑集中在后端,前端只需携带支付所需的数据请求后端接口然后根据返回结果做相应成功失败处理即可。
1871 0