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