财付通接口文档及代码

上传人:M****1 文档编号:563154246 上传时间:2023-05-26 格式:DOCX 页数:14 大小:111.40KB
返回 下载 相关 举报
财付通接口文档及代码_第1页
第1页 / 共14页
财付通接口文档及代码_第2页
第2页 / 共14页
财付通接口文档及代码_第3页
第3页 / 共14页
财付通接口文档及代码_第4页
第4页 / 共14页
财付通接口文档及代码_第5页
第5页 / 共14页
点击查看更多>>
资源描述

《财付通接口文档及代码》由会员分享,可在线阅读,更多相关《财付通接口文档及代码(14页珍藏版)》请在金锄头文库上搜索。

1、文档供参考,可复制、编制,期待您的好评与关注! 财付通API接口文档样例代码引言文档概述 本文描述了财付通开放平台的JAVA SDK,帮助开发者轻松实现在线支付、收付款等功能。文档详细介绍了财付通开放平台的工作方式和开发过程,可以帮助开发人员快速入门并掌握开发技能,同时也可以作为日后接口参数以及参数类型的速查手册。阅读对象 具有WEB程序开发背景,了解JAVA语言。业务术语术语说明ISV独立软件供应商 / Independent Software Vendor,可以是商户、个人或者第三方中介开发者财付通APP指ISV使用财付通开放平台SDK开发的WEB应用程序,运行于第三方服务器上为最终用户提

2、供服务商户指财付通的商户,商家可以是ISV。开放平台财付通提供给ISV的开发注册、应用管理、沙箱测试平台。最终用户指通过财付通开放平台使用财付通APP的财付通用户接口业务流程支付流程 支付流程中,用户在财付通APP中购买业务,通过财付通支付平台进行支付。典型业务流程如下: 买家在财付通APP上浏览下单购买一个商品,财付通APP会生成一个支付链接,此链接通过用户的浏览器跳转到财付通开放平台,财付通通过此链接获取支付请求的参数,引导用户完成支付过程。 用户在财付通完成支付后,财付通通过return_url将用户浏览重新定向到财付通APP,财付通APP向用户提示订单状态和后续操作。同时,财付通会通过

3、后台回调财付通APP的notify_url,财付通APP在收到支付结果通知后可以根据通知ID查询通知内容,在确保支付成功后再进行业务逻辑处理(例如发货),这样可以进一步提高安全性,防止伪支付成功结果的诈骗。通知查询/订单查询流程 通知查询/订单查询是指财付通APP向财付通系统发送查询请求,并同步等待财付通系统处理完毕后返回的响应数据。数据交互是财付通APP与财付通服务器直接通信。 例如用户在财付通APP查询时,财付通APP要确认用户某个订单是否支付成功,可以向财付通发送一个查询请求,财付通收到请求后返回查询结果,财付通APP处理结果后再显示给用户。后台通知流程 后台通知是指财付通系统主动向财付

4、通APP发送通知数据,并同步等待财付通APP处理完毕后返回的响应数据。数据交互是财付通服务器与财付通APP直接通信,一般请求采用http的get或post,应答用字符串格式。 用户在财付通支付成功后,财付通会在后台通过notify_url向财付通APP发起通知,财付通APP处理后成功返回success,失败返回fail或其他字符。补单机制 对后台通知流程,如果财付通收到财付通APP的应答不是success或由于网络异常超时,财付通认为通知失败,财付通会通过一定的策略(如1分钟、2分钟、4分钟、8分钟、16分钟、32分钟,共6次)定期重新发起通知,尽可能提高通知的成功率,但财付通不保证通知最终能

5、成功。 由于上述原因,可能存在同样的通知多次发送给财付通APP的情况。财付通APP必须能够正确处理,在收到重复的后台通知不重复引发业务流程(例如发货)。 财付通推荐的做法是,当收到财付通发送的通知消息时,需要检查本系统内订单的状态,判断该通知是否已经处理过。为防止并发产生的问题,在对业务数据进行状态检查和处理之前,要求采用加锁判断进行并发控制。功能划分 财付通APP负责与之业务相关的代码和页面。 财付通开放平台提供支付相关的业务功能和页面。具体业务功能请参照后面章节SDK说明 支付页面如下: 在小钱包中: 在普通浏览器中:SDK说明概述API说明类名说明com.tenpay.api.PayRe

6、quest支付请求com.tenpay.api.PayResponse支付响应com.tenpay.api.OrderQueryRequest订单查询请求com.tenpay.api.OrderQueryResponse订单查询响应com.tenpay.api.NotifyQueryRequest通知查询请求com.tenpay.api.NotifyQueryResponse通知查询响应com.tenpay.api.ShareLoginState共享登录用户信息共享登录用户信息接口:1 用户跳转到应用时,初始化ShareLoginState对象,ShareLoginState.getUserI

7、d()即可获得当前用户的id支付接口,常见开发步骤如下:2 初始化请求对象PayRequest3 设置请求系统级参数(应用ID等),例如PayRequest.setAppid(应用ID)4 设置请求业务级参数,例如PayRequest.setParameters(参数名称, 参数值)5 生成跳转URL,例如PayRequest.getURL()6 将用户重定向到跳转URL,例如Servlet/JSP中的重定向方法response.sendRedirect()或用Javascript进行页面跳转通知查询或订单查询,常见开发步骤如下:7 初始化请求对象,例如NotifyQueryRequest或O

8、rderQueryRequest8 设置请求系统级参数(应用ID等),例如NotifyQueryRequest.setAppid(应用ID)9 设置请求业务级参数,例如NotifyQueryRequest.setParameters(参数名称, 参数值)10 通过NotifyQueryRequest.send()方法将请求发送到接口并获得响应对象,例如NotifyQueryResponse response = NotifyQueryRequest.send()11 判断订单支付状态,例如NotifyQueryResponse.isPaySuccessful()12 从响应对象中获取参数值,进

9、行相应处理,例如NotifyQueryResponse.getParameter(参数名)后台通知交互模式,常见开发步骤如下:13 构造一个Servlet或JSP接收开放平台的回调14 初始化响应对象PayResponse15 判断订单支付状态,例如PayResponse.isPaySuccessful()16 从响应对象中获取参数值,进行相应处理,例如PayResponse.getParameter(参数名)调用过程支付类支付跳转业务功能 买家在财付通APP中下订单后付款,财付通APP调用财付通开放平台支付接口生成支付URL,页面跳转到财付通支付中心或银行。用户完成支付后,财付通把用户引导回

10、财付通APP指定的页面(return_url),并通过回调支付请求中的notify_url反馈支付结果。接口调用方向开发者开发应用调用财付通开放接口请求 com.tenpay.api.NotifyQueryRequest 通知查询请求 方法列表 /* * 构造方法 * param secretKey */ public NotifyQueryRequest(String secretKey); /* * 设置应用ID * * param appid * 应用ID */ public void setAppid(String appid); /* * 设置是否在沙箱环境 * * param in

11、SandBox * true表示请求发送到沙箱环境,false表示请求发送到正式环境 */ public void setInSandBox(boolean inSandBox); /* * 设置业务参数 * * param key * 参数名称 * param value * 参数值 */ public void setParameter(String key, String value); /* * 调用开放平台接口发送请求,获取响应 * * return 接口调用的返回结果 * throws Exception */ public CommonResponse send() throws

12、 Exception; 参数名称详见下表参数名称必填类型说明notify_id是String(64)支付成功后,财付通系统反馈的通知ID此参数来源详见3.1.2.5章节参数列表中的notify_idsign_key_index否Int多密钥支持的密钥序号,默认1sign_type否String(8)签名类型,取值:MD5、RSA,默认:MD5,暂只支持MD5service_version否String(8)版本号,默认为1.0返回结果 com.tenpay.api.NotifyQueryResponse通知查询响应 方法列表 /* * 判断支付结果 * * return true表示支付成功,

13、false表示支付处于其他状态,需要调用getPayInfo()方法获取详细说明 */ public boolean isPaySuccessful(); /* * 获取支付结果信息 * * return 支付结果说明 */ public String getPayInfo(); /* * 获取响应参数 * * param key 参数名称 * return 参数值 */ public String getParameter(String key); 参数名称详见下表参数名称必填类型说明total_fee是Int用户实际支付的金额,单位为分,如果discount有值,通知的total_fee + discount = 请求的total_feetransaction_id是String(28)财付通交易号out_trade_no是String(32)财付通APP系统的订单号,与请求一致。time_end是String(14)支付完成时间,格式为yyyymmddhhmmss,如2009年12月27日9点10分10秒表示为20091227091010。时区为GMT+8 beijing。该时间取自财付通服务器input_charset否String(8)字符编码,取值:GBK、UTF-8,默认:GBK。sign_key_index

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 国内外标准规范

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号