All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.binarywang.wxpay.service.EntPayService Maven / Gradle / Ivy

The newest version!
package com.github.binarywang.wxpay.service;

import com.github.binarywang.wxpay.bean.entpay.*;
import com.github.binarywang.wxpay.bean.entwxpay.EntWxEmpPayRequest;
import com.github.binarywang.wxpay.exception.WxPayException;

/**
 * 
 *  企业付款相关服务类.
 *  Created by BinaryWang on 2017/12/19.
 * 
* * @author Binary Wang */ public interface EntPayService { /** *
   * 企业付款API.
   * 企业付款业务是基于微信支付商户平台的资金管理能力,为了协助商户方便地实现企业向个人付款,针对部分有开发能力的商户,提供通过API完成企业付款的功能。
   * 比如目前的保险行业向客户退保、给付、理赔。
   * 企业付款将使用商户的可用余额,需确保可用余额充足。查看可用余额、充值、提现请登录商户平台“资金管理”https://pay.weixin.qq.com/进行操作。
   * 注意:与商户微信支付收款资金并非同一账户,需要单独充值。
   * 文档详见: https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_2
   * 接口链接:https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers
   * 
* * @param request 请求对象 * @return the ent pay result * @throws WxPayException the wx pay exception */ EntPayResult entPay(EntPayRequest request) throws WxPayException; /** *
   * 查询企业付款API.
   * 用于商户的企业付款操作进行结果查询,返回付款操作详细结果。
   * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_3
   * 接口链接:https://api.mch.weixin.qq.com/mmpaymkttransfers/gettransferinfo
   * 
* * @param partnerTradeNo 商户订单号 * @return the ent pay query result * @throws WxPayException the wx pay exception */ EntPayQueryResult queryEntPay(String partnerTradeNo) throws WxPayException; /** *
   * 查询企业付款API.
   * 用于商户的企业付款操作进行结果查询,返回付款操作详细结果。
   * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_3
   * 接口链接:https://api.mch.weixin.qq.com/mmpaymkttransfers/gettransferinfo
   * 
* * @param request 请求对象 * @return the ent pay query result * @throws WxPayException the wx pay exception */ EntPayQueryResult queryEntPay(EntPayQueryRequest request) throws WxPayException; /** *
   * 获取RSA加密公钥API.
   * RSA算法使用说明(非对称加密算法,算法采用RSA/ECB/OAEPPadding模式)
   * 1、 调用获取RSA公钥API获取RSA公钥,落地成本地文件,假设为public.pem
   * 2、 确定public.pem文件的存放路径,同时修改代码中文件的输入路径,加载RSA公钥
   * 3、 用标准的RSA加密库对敏感信息进行加密,选择RSA_PKCS1_OAEP_PADDING填充模式
   * (eg:Java的填充方式要选 " RSA/ECB/OAEPWITHSHA-1ANDMGF1PADDING")
   * 4、 得到进行rsa加密并转base64之后的密文
   * 5、 将密文传给微信侧相应字段,如付款接口(enc_bank_no/enc_true_name)
   *
   * 接口默认输出PKCS#1格式的公钥,商户需根据自己开发的语言选择公钥格式
   * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_7&index=4
   * 接口链接:https://fraud.mch.weixin.qq.com/risk/getpublickey
   * 
* * @return the public key * @throws WxPayException the wx pay exception */ String getPublicKey() throws WxPayException; /** * 企业付款到银行卡. *
   * 用于企业向微信用户银行卡付款
   * 目前支持接口API的方式向指定微信用户的银行卡付款。
   * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_2
   * 接口链接:https://api.mch.weixin.qq.com/mmpaysptrans/pay_bank
   * 
* * @param request 请求对象 * @return the ent pay bank result * @throws WxPayException the wx pay exception */ EntPayBankResult payBank(EntPayBankRequest request) throws WxPayException; /** * 企业付款到银行卡查询. *
   * 用于对商户企业付款到银行卡操作进行结果查询,返回付款操作详细结果。
   * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_3
   * 接口链接:https://api.mch.weixin.qq.com/mmpaysptrans/query_bank
   * 
* * @param partnerTradeNo 商户订单号 * @return the ent pay bank query result * @throws WxPayException the wx pay exception */ EntPayBankQueryResult queryPayBank(String partnerTradeNo) throws WxPayException; /** * 企业付款到银行卡查询. *
   * 用于对商户企业付款到银行卡操作进行结果查询,返回付款操作详细结果。
   * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_3
   * 接口链接:https://api.mch.weixin.qq.com/mmpaysptrans/query_bank
   * 
* * @param request 请求对象 * @return the ent pay bank query result * @throws WxPayException the wx pay exception */ EntPayBankQueryResult queryPayBank(EntPayBankQueryRequest request) throws WxPayException; /** * 企业发送微信红包给个人用户 *
   *   文档地址:https://work.weixin.qq.com/api/doc
   *   接口地址: https://api.mch.weixin.qq.com/mmpaymkttransfers/sendworkwxredpack
   * 
* @param request 请求对象 * @return the wx pay send redpack result * @throws WxPayException the wx pay exception */ EntPayRedpackResult sendEnterpriseRedpack(EntPayRedpackRequest request) throws WxPayException; /** * 企业发送微信红包查询 *
   *   文档地址:https://work.weixin.qq.com/api/doc
   *   接口地址: https://api.mch.weixin.qq.com/mmpaymkttransfers/queryworkwxredpack
   * 
* @param request 请求对象 * @return the wx pay send redpack result * @throws WxPayException the wx pay exception */ EntPayRedpackQueryResult queryEnterpriseRedpack(EntPayRedpackQueryRequest request) throws WxPayException; /** * 向员工付款 * 文档详见 https://work.weixin.qq.com/api/doc/90000/90135/90278 * 接口链接 https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/paywwsptrans2pocket * * @param request 请求对象 * @return EntPayResult the ent pay result * @throws WxPayException the wx pay exception */ EntPayResult toEmpPay(EntWxEmpPayRequest request) throws WxPayException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy