1 Star 0 Fork 39

nickyou / ymate-payment-v2

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README
Apache-2.0

YMP-Payment v2

基于YMP框架实现的第三方支付(包括支付宝、微信支付、银联支付、京东支付、百度钱包和QQ钱包等)接入模块,目前已实现:

名称 状态
支付宝 测试通过
微信支付 重构完成,待测试
银联支付 整理中
京东支付 待整理
百度钱包 待整理
QQ钱包 待整理

支付宝 (AliPay)

当前模块已完成支付宝电脑网站和手机网站最新发布的支付能力相关API的封装并测试通过。

  • 电脑网站支付API列表 (更新时间: 2017/05/04)

    接口英文名 接口中文名 API文档
    alipay.trade.page.pay 统一收单下单并支付页面接口 查看文档
    alipay.trade.refund 统一收单交易退款接口 查看文档
    alipay.trade.fastpay.refund.query 统一收单交易退款查询接口 查看文档
    alipay.trade.query 统一收单线下交易查询接口 查看文档
    alipay.trade.close 统一收单交易关闭接口 查看文档
    alipay.data.dataservice.bill.downloadurl.query 查询对账单下载地址 查看文档
  • 手机网站支付API列表 (更新时间: 2016/08/12)

    接口英文名 接口中文名 API文档
    alipay.trade.wap.pay 手机网站支付接口 查看文档
    alipay.trade.refund 交易退款接口 查看文档
    alipay.trade.fastpay.refund.query 交易退款查询接口 查看文档
    alipay.trade.query 交易查询接口 查看文档
    alipay.trade.close 交易关闭接口 查看文档
    alipay.data.dataservice.bill.downloadurl.query 查询账单下载地址接口 查看文档
Maven包依赖
<dependency>
    <groupId>net.ymate.payment</groupId>
    <artifactId>ymate-payment-alipay</artifactId>
    <version>2.0.0</version>
</dependency>
AliPay使用方法说明
  • 实现支付事件处理器接口net.ymate.payment.alipay.IAliPayEventHandler,示例代码如下:

    public class AliPayEventHandler implements IAliPayEventHandler {
    
        private static final Log _LOG = LogFactory.getLog(AliPayEventHandler.class);
    
        /**
         * @param orderId 订单Id
         * @param attach  附加信息
         * @return 创建PC支付请求接口参数对象
         * @throws Exception 可能产生任何异常
         */
        public TradePagePayData buildTradePagePayData(String orderId, String attach) throws Exception {
            TradePagePayData _data = new TradePagePayData(UUIDUtils.UUID(), "99.99", "捐赠订单");
            _data.setPassbackParams(attach);
            //
            return _data;
        }
    
        /**
         * @param orderId 订单Id
         * @param attach  附加信息
         * @return 创建WAP支付请求接口参数对象
         * @throws Exception 可能产生任何异常
         */
        public TradeWapPayData buildTradeWapPayData(String orderId, String attach) throws Exception {
            return new TradeWapPayData(UUIDUtils.UUID(), "99.99", "捐赠订单");
        }
    
        public void onNotifyReceived(AliPayBaseNotify notifyData) throws Exception {
            _LOG.debug("接收到异步通知消息: " + JSON.toJSONString(notifyData));
        }
    
        public IView onReturnCallback(AliPayBaseReturn returnData) throws Exception {
            String _jsonStr = JSON.toJSONString(returnData);
            _LOG.debug("接收到同步通知消息: " + _jsonStr);
            //
            return View.jsonView(_jsonStr);
        }
    
        public void onExceptionCaught(Throwable cause) throws Exception {
            _LOG.error("发生了异常: ", cause);
        }
    }
  • 请求支付,访问URL地址格式如下:

    PC端支付:

    http://<域名>/payment/alipay/<支付宝APP_ID>/page?state=<订单编号>&attach=<附加信息>

    移动端支付:

    http://<域名>/payment/alipay/<支付宝APP_ID>/wap?state=<订单编号>&attach=<附加信息>

    URL参数说明:

    • 支付宝APP_ID:支付宝分配给开发者的应用ID,必选参数;

      若模块中配置默认支付宝开发者帐户ID或使用默认账户提供者,则可以直接使用default访问;

    • 订单编号:业务订单唯一标识,必选参数;

      该参数将被传递至支付事件处理接口的buildTradePagePayDatabuildTradeWapPayData方法;

    • 附加信息:该参数值将被原样返回;

  • 异步通知,访问URL地址格式如下:

    http://<域名>/payment/alipay/notify
  • 同步跳转通知,访问URL地址格式如下:

    http://<域名>/payment/alipay/callback
AliPay模块接口方法说明
  • 创建支付请求:

    // PC端支付:
    AliPay.get().tradePagePay("<订单编号>", "<附加信息>").build().executeActionForm();
    
    // WAP端支付:
    AliPay.get().tradeWapPay("<订单编号>", "<附加信息>").build().executeActionForm();
  • 统一收单线下交易查询:

    AliPayTradeQuery.Response _query = AliPay.get()
            .tradeQuery("<支付宝APP_ID>", "<TRADE_NO>", "<OUT_TRADE_NO>")
            .build().execute();
  • 统一收单交易退款:

    AliPayTradeRefund.Response _refund = AliPay.get()
            .tradeRefund("<支付宝APP_ID>", new TradeRefundData("<OUT_TRADE_NO>", "<TRADE_NO>", "99.00"))
            .build().execute();
  • 统一收单交易退款查询:

    AliPayTradeRefundQuery.Response _refundQuery = AliPay.get()
            .tradeRefundQuery("<支付宝APP_ID>", "<TRADE_NO>", "<OUT_TRADE_NO>", "<OUT_REQUEST_NO>"))
            .build().execute();
  • 统一收单交易关闭:

    AliPayTradeClose.Response _close = AliPay.get()
            .tradeClose("<支付宝APP_ID>", "<TRADE_NO>", "<OUT_TRADE_NO>"))
            .build().execute();
  • 查询对账单下载地址:

    AliPayBillDownloadUrlQuery.Response _download = AliPay.get()
            .billDownloadUrlQuery("<支付宝APP_ID>", "<BILL_TYPE>", "<BILL_DATE>"))
            .build().execute();
AliPay模块配置参数说明
#-------------------------------------
# payment.alipay 模块初始化参数
#-------------------------------------
    
# 支付接口网关URL地址, 默认值: https://openapi.alipay.com/gateway.do
ymp.configs.payment.alipay.gateway_url=
    
# 支付宝开发者账户提供者接口实现类, 若未提供则使用默认配置
ymp.configs.payment.alipay.account_provider_class=
    
# 支付事件处理器, 必选参数
ymp.configs.payment.alipay.event_handler_class=
    
# 默认支付宝开发者帐户ID, 默认值: 若采用账户提供者接口默认实现时取值默认应用ID, 否则为空
ymp.configs.payment.alipay.default_account_id=
    
# 禁用报文签名验证(验签), 默认值: false
ymp.configs.payment.alipay.sign_check_disabled=
    
#-------------------------------------
# 默认支付宝开发者账户配置参数
#-------------------------------------
    
# 支付宝分配给开发者的应用ID
ymp.configs.payment.alipay.app_id=
    
# 商户生成签名字符串所使用的签名算法类型,目前支持RSA2和RSA,推荐使用RSA2
ymp.configs.payment.alipay.sign_type=
    
# 私钥
ymp.configs.payment.alipay.private_key=
    
# 公钥
ymp.configs.payment.alipay.public_key=
    
# 请求使用的编码格式
ymp.configs.payment.alipay.charset=
    
# 返回格式
ymp.configs.payment.alipay.format=
    
# 支付宝服务器主动通知商户服务器里指定的页面HTTP/HTTPS路径
ymp.configs.payment.alipay.notify_url=
    
# 同步返回地址,HTTP/HTTPS开头字符串
ymp.configs.payment.alipay.return_url=

微信支付 (WxPay)

当前模块已完成微信支付最新发布的刷卡支付、公众号支付、扫码支付、H5支付、现金红包和企业付款等支付能力相关API的封装。

接口名称 模块方法 官方文档
统一下单 WxPay.get().unifiedOrder(...) 查看文档
提交刷卡支付 WxPay.get().microPay(...) 查看文档
查询订单 WxPay.get().orderQuery(...) 查看文档
撤销订单 WxPay.get().reverse(...) 查看文档
关闭订单 WxPay.get().closeOrder(...) 查看文档
申请退款 WxPay.get().refund(...) 查看文档
查询退款 WxPay.get().refundQuery(...) 查看文档
下载对账单 WxPay.get().downloadBill(...) 查看文档
支付结果通知 - 查看文档
转换短链接 WxPay.get().shortUrl(...) 查看文档
授权码查询openid WxPay.get().authCodeToOpenId(...) 查看文档
发放普通红包 WxPay.get().redPackSend(...) 查看文档
发放裂变红包 WxPay.get().redPackSendGroup(...) 查看文档
查询红包记录 WxPay.get().redPackInfo(...) 查看文档
企业付款 WxPay.get().mchPay(...) 查看文档
查询企业付款 WxPay.get().mchPayQuery(...) 查看文档

点击这里查看完整的微信支付开发文档

Maven包依赖
<dependency>
    <groupId>net.ymate.payment</groupId>
    <artifactId>ymate-payment-wxpay</artifactId>
    <version>2.0.0</version>
</dependency>
WxPay使用方法说明
  • 实现支付事件处理器接口net.ymate.payment.wxpay.IWxPayEventHandler,示例代码如下:

    public class WxPayEventHandler implements IWxPayEventHandler {
    
        private static final Log _LOG = LogFactory.getLog(WxPayEventHandler.class);
    
        /**
         * @param tradeType 交易类型
         * @param orderId   订单ID
         * @param attach    附加信息
         * @return 构建微信统一支付请求数据对象
         * @throws Exception 可能产生的任何异常
         */
        public WxPayUnifiedOrder buildUnifiedOrderRequest(WxPayAccountMeta accountMeta, IWxPay.TradeType tradeType, String orderId, String attach) throws Exception {
            return new WxPayUnifiedOrder(accountMeta, "捐赠订单", orderId, 9999, "192.168.199.1", "", tradeType.name()).attach(attach);
        }
    
        /**
         * 异步支付通知消息到达事件处理方法,该方法的执行过程中若无任何异常被抛出则视为执行成功并向微信通知服务返回SUCCESS字符串
         *
         * @param notifyData 异步通知对象
         * @throws Exception 可能产生的任何异常
         */
        public void onNotifyReceived(WxPayNotifyResponse notifyData) throws Exception {
            _LOG.debug("接收到异步通知消息: " + notifyData.getOriginalContent());
        }
    
        /**
         * @param orderId 订单ID
         * @return 返回是否需要发启订单状态查询
         * @throws Exception 可能产生的任何异常
         */
        public boolean onReturnCallback(String orderId) throws Exception {
            // 此处判断指定的订单是否需要向微信支付发起状态查询
            return true;
        }
    
        /**
         * 异常处理方法
         *
         * @param cause 产生的异常对象
         * @throws Exception 可能产生的任何异常
         */
        public void onExceptionCaught(Throwable cause) throws Exception {
            _LOG.error("发生了异常: ", cause);
        }
    
        /**
         * @param appId 微信公众号应用ID
         * @return 获取微信JS接口的临时票据
         * @throws Exception 可能产生的任何异常
         */
        public String getJsApiTicket(String appId) throws Exception {
            // 此处请根据需求返回正确的JS接口临时票据
            return "bxLdikRXVbTPdHSM05e5u5sUoXNKd8-41ZO3MhKoyN5OfkWITDGgnr2fwJ0m9E8NYzWKVZvdVtaUgWvsdshFKA";
        }
    }
  • 请求支付,访问URL地址格式如下:

    微信JS_API模式:

    http://<域名>/payment/wxpay/jsapi/<APP_ID>?open_id=<OPEN_ID>state=<订单编号>&attach=<附加信息>&debug=<true|false>

    微信H5支付模式:

    http://<域名>/payment/wxpay/<APP_ID>/mweb?state=<订单编号>&attach=<附加信息>&redirect_url=<重定向URL地址>

    微信Native(原生)支付模式一:

    商户按固定格式生成链接二维码,用户扫码后调微信会将productid和用户openid发送到商户设置的链接上,商户收到请求生成订单,调用统一支付接口下单提交到微信,微信会返回给商户prepayid。

    http://<域名>/payment/wxpay/<APP_ID>/native/static?state=<订单编号>&attach=<附加信息>

    微信Native(原生)支付模式二:

    商户生成订单,先调用统一支付接口获取到code_url,此URL直接生成二维码,用户扫码后调起支付。

    http://<域名>/payment/wxpay/<APP_ID>/native/dynamic?state=<订单编号>&attach=<附加信息>

    URL参数说明:

    • APP_ID:公众账号ID,必选参数;

      若模块中配置默认公众账号ID或使用默认账户提供者,则可以直接使用default访问;

    • OPEN_ID:微信用户唯一标识;

    • 订单编号:业务订单唯一标识,必选参数;

    • 附加信息:该参数值将被原样返回;

  • 异步通知,访问URL地址格式如下:

    http://<域名>/payment/wxpay/notify
  • 同步跳转通知(订单状态主动检查),访问URL地址格式如下:

    http://<域名>/payment/wxpay/<APP_ID>/callback?state=<订单编号>
  • 动态生成支付二维码,访问URL地址格式如下:

    http://<域名>/payment/wxpay/qrcode/<DATA>?width=300&height=300

    参数说明:

    • DATA:二维码数据,在调用微信原生支付控制器时将会返回该数据;

    • width:图片宽度(<=300),默认值:300;

    • height:图片高度(<=300),默认值:300;

WxPay模块配置参数说明
#-------------------------------------
# payment.wxpay 模块初始化参数
#-------------------------------------

# 微信支付账户提供者接口实现类, 若未提供则使用默认配置
ymp.configs.payment.wxpay.account_provider_class=

# 支付事件处理器, 必选参数
ymp.configs.payment.wxpay.event_handler_class=

# 默认微信支付帐户ID, 默认值: 若采用账户提供者接口默认实现时取值默认应用ID, 否则为空
ymp.configs.payment.wxpay.default_account_id=

# 调用JS支付的JSP视图文件路径, 默认值: wxpay_jsapi
ymp.configs.payment.wxpay.jsapi_view=

# 调用扫码支付的JSP视图文件路径, 默认值: wxpay_native
ymp.configs.payment.wxpay.native_view=

# 禁用报文签名验证(验签), 默认值: false
ymp.configs.payment.wxpay.sign_check_disabled=

#-------------------------------------
# 默认微信支付账户配置参数
#-------------------------------------

# 公众帐号APP_ID
ymp.configs.payment.wxpay.app_id=

# 商户号
ymp.configs.payment.wxpay.mch_id=

# 商号密钥
ymp.configs.payment.wxpay.mch_key=

# 是否开启沙箱测试模式, 默认值: false
ymp.configs.payment.wxpay.sandbox_enabled=

# 获取沙箱测试模式下的接口URL地址前缀, 默认值: sandboxnew
ymp.configs.payment.wxpay.sandbox_prefix=

# 证书文件路径
ymp.configs.payment.wxpay.cert_file_path=

# 异步通知URL路径
ymp.configs.payment.wxpay.notify_url=

银联支付 (UnionPay)

正在整理中...,请稍后!

One More Thing

YMP不仅提供便捷的Web及其它Java项目的快速开发体验,也将不断提供更多丰富的项目实践经验。

感兴趣的小伙伴儿们可以加入 官方QQ群480374360,一起交流学习,帮助YMP成长!

了解更多有关YMP框架的内容,请访问官网:http://www.ymate.net/

Apache License Version 2.0, January 2004 http://www.apache.org/licenses/ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 1. Definitions. "License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document. "Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License. "Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity. "You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License. "Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files. "Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types. "Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below). "Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof. "Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution." "Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work. 2. Grant of Copyright License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form. 3. Grant of Patent License. Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed. 4. Redistribution. You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions: (a) You must give any other recipients of the Work or Derivative Works a copy of this License; and (b) You must cause any modified files to carry prominent notices stating that You changed the files; and (c) You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and (d) If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License. You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License. 5. Submission of Contributions. Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions. 6. Trademarks. This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file. 7. Disclaimer of Warranty. Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License. 8. Limitation of Liability. In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages. 9. Accepting Warranty or Additional Liability. While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability. END OF TERMS AND CONDITIONS APPENDIX: How to apply the Apache License to your work. To apply the Apache License to your work, attach the following boilerplate notice, with the fields enclosed by brackets "{}" replaced with your own identifying information. (Don't include the brackets!) The text should be enclosed in the appropriate comment syntax for the file format. We also recommend that a file or class name and description of purpose be included on the same "printed page" as the copyright notice for easier identification within third-party archives. Copyright {yyyy} {name of copyright owner} Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

简介

基于YMP框架实现的第三方支付接入模块,包括支付宝、微信支付、银联支付、京东支付、百度钱包和QQ钱包等; 展开 收起
Java
Apache-2.0
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
Java
1
https://gitee.com/nickyou/ymate-payment-v2.git
git@gitee.com:nickyou/ymate-payment-v2.git
nickyou
ymate-payment-v2
ymate-payment-v2
master

搜索帮助

14c37bed 8189591 565d56ea 8189591