1、企业付款的介绍
所谓企业付款指的是,在功能开放后诸如保险行业的客户理赔、退保、商品退款、发放征集活动奖金、抽奖互动等操作都可以通过企业付款完成。而此前,微信支付只能提供客户向企业单向付款。
商户如果需要给用户付款,可以直接将钱打入用户的“微信零钱”中,微信支付将做零钱入账消息通知,零钱收支明细会展示相应记录。针对无零钱账户的历史客户端版本,资金将进入用户的红包账户,微信支付无消息通知用户,企业可选择自行触达用户。
通过认证的企业号可以开通微信支付功能。通过认证的企业号可以管理平台的“服务中心”的“微信支付”入口里进行微信支付功能申请。而开通微信支付功能后,企业号将拥有两项功能:收款和付款。如果是用户号对企业号付款,款项将会进入企业号所关联的商户号中。同时,企业号可以通过微信红包或微信转账的形式对用户号付款。
企业付款,提供企业向用户付款的功能,支持企业通过api接口付款,或通过微信支付商户平台网页功能操作付款。
涉及资金操作的功能,安全性要求较高,需要操作员安装证书(商户平台-账户设置-密码安全-操作证书);通过api或网页操作,付款至目标用户(企业可根据appid+openid锁定目标用户)。针对已实名认证的用户,微信支付可提供校验真实姓名一致性的可选功能。
企业付款提示:
◆ 给同一个实名用户付款,单笔单日限额2w/2w
◆ 给同一个非实名用户付款,单笔单日限额2000/2000
◆ 一个商户同一日付款总额限额100w
◆仅支持商户号已绑定的appid;
◆针对付款的目标用户,已微信支付实名认证的用户可提供校验真实姓名的功能,未实名认证的用户无法校验,企业可根据自身业务的安全级别选择验证类型;
◆付款金额必须小于或等于商户当前可用余额的金额;
◆ 已付款的记录,企业可通过企业付款查询查看相应数据。
2、企业付款api企业付款业务是基于微信支付商户平台的资金管理能力,为了协助商户方便地实现企业向个人付款,针对部分有开发能力的商户,提供通过api完成企业付款的功能。
比如目前的保险行业向客户退保、给付、理赔。
企业付款将使用商户的可用余额,需确保可用余额充足。查看可用余额、充值、提现请登录商户平台“资金管理”进行操作。
接口地址
接口链接:https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers
是否需要证书
请求需要双向证书。 详见证书使用
请求参数
提交数据示例:
<xml>
<mch_appid>wxe062425f740c30d8</mch_appid>
<mchid>10000098</mchid>
<nonce_str>3pg2j4iltkch16cq2502si8znmtm67vs</nonce_str>
<partner_trade_no>100000982014120919616</partner_trade_no>
<openid>oho4gt7wvpxit1a9gjfamymizy1s</openid>
<check_name>option_check</check_name>
<re_user_name>张三</re_user_name>
<amount>100</amount>
<desc>节日快乐!</desc>
<spbill_create_ip>10.2.3.10</spbill_create_ip>
<sign>c97bdbacf37622775366f38b629f45e3</sign>
</xml>
成功返回的数据示例:
<xml>
<return_code><![cdata[success]]></return_code>
<return_msg><![cdata[]]></return_msg>
<mch_appid><![cdata[wxec38b8ff840bd989]]></mch_appid>
<mchid><![cdata[10013274]]></mchid>
<device_info><![cdata[]]></device_info>
<nonce_str><![cdata[lxudzmnrjpcxzxlx0q]]></nonce_str>
<result_code><![cdata[success]]></result_code>
<partner_trade_no><![cdata[10013574201505191526582441]]></partner_trade_no>
<payment_no><![cdata[1000018301201505190181489473]]></payment_no>
<payment_time><![cdata[2015-05-19 15:26:59]]></payment_time>
</xml>
根据上面的接口描述,以及输入,返回参数,我们可以构建对应的c#代码的接口
根据上面的接口定义,我们可以定义接口信息如下所示
/// <summary>
/// 微信支付接口
/// </summary>
public interface itenpayapi
{
/// <summary>
/// 企业付款(请求需要双向证书)
/// 企业付款业务是基于微信支付商户平台的资金管理能力,为了协助商户方便地实现企业向个人付款,
/// 针对部分有开发能力的商户,提供通过api完成企业付款的功能。 比如目前的保险行业向客户退保、给付、理赔。
/// 企业付款将使用商户的可用余额,需确保可用余额充足。查看可用余额、充值、提现请登录商户平台“资金管理”进行操作。https://pay.weixin.qq.com/
/// 注意:与商户微信支付收款资金并非同一账户,需要单独充值。
/// </summary>
/// <param name="json">企业支付数据</param>
/// <returns></returns>
corppayresult corppay(corppayjson json);
..............
其中上面的corppayjson 和corppayresult 分别是传入参数和获取的结果内容,两者的对象信息根据参数进行定义即可。
/// <summary>
/// 企业付款的数据信息
/// </summary>
public class corppayjson
{
public corppayjson()
{
this.check_name = "force_check";
}
/// <summary>
/// 微信支付分配的终端设备号
/// </summary>
public string device_info { get; set; }
/// <summary>
/// 用户openid
/// </summary>
public string openid { get; set; }
/// <summary>
/// 校验用户姓名选项,可以使用 paycheckname枚举对象获取名称
/// no_check:不校验真实姓名
/// force_check:强校验真实姓名(未实名认证的用户会校验失败,无法转账)
/// option_check:针对已实名认证的用户才校验真实姓名(未实名认证用户不校验,可以转账成功)
/// </summary>
public string check_name { get; set; }
/// <summary>
/// 收款用户真实姓名。
/// 如果check_name设置为force_check或option_check,则必填用户真实姓名
/// </summary>
public string re_user_name { get; set; }
/// <summary>
/// 企业付款金额,单位为分
/// </summary>
public int amount { get; set; }
/// <summary>
/// 企业付款操作说明信息。必填。
/// </summary>
public string desc { get; set; }
/// <summary>
/// 调用接口的机器ip地址
/// </summary>
public string spbill_create_ip { get; set; }
}
/// <summary>
/// 企业付款操作的返回结果
/// </summary>
public class corppayresult : payresult
{
/// <summary>
/// 微信分配的公众账号id(企业号corpid即为此appid)
/// </summary>
public string mch_appid { get; set; }
/// <summary>
/// 微信支付分配的终端设备号
/// </summary>
public string device_info { get; set; }
/// <summary>
/// 商户使用查询api填写的单号的原路返回.
/// </summary>
public string partner_trade_no { get; set; }
/// <summary>
/// 企业付款成功,返回的微信订单号
/// </summary>
public string payment_no { get; set; }
/// <summary>
/// 企业付款成功时间
/// </summary>
public string payment_time { get; set; }
}
企业付款的api实现和前面两种红包的处理方式 差不多,一个是传入常规的账号信息,一个是传入业务参数,然后提交获取结果即可,具体代码如下所示。
/// <summary>
/// 企业付款(请求需要双向证书)
/// 企业付款业务是基于微信支付商户平台的资金管理能力,为了协助商户方便地实现企业向个人付款,
/// 针对部分有开发能力的商户,提供通过api完成企业付款的功能。 比如目前的保险行业向客户退保、给付、理赔。
/// 企业付款将使用商户的可用余额,需确保可用余额充足。查看可用余额、充值、提现请登录商户平台“资金管理”进行操作。https://pay.weixin.qq.com/
/// 注意:与商户微信支付收款资金并非同一账户,需要单独充值。
/// </summary>
/// <param name="json">企业支付数据</param>
/// <returns></returns>
public corppayresult corppay(corppayjson json)
{
checkaccount();//检查accountinfo的对象属性值
wxpaydata data = new wxpaydata();
data.setvalue("mch_appid", accountinfo.uniteappid);//公众账号appid, 注意是mch_appid,而非wxappid
data.setvalue("mchid", accountinfo.mchid);//商户号, 注意是mchid而非mch_id
data.setvalue("nonce_str", data.generatenoncestr());//随机字符串
data.setvalue("spbill_create_ip", networkutil.getipaddress());//终端ip
data.setvalue("partner_trade_no", data.generateouttradeno(accountinfo.mchid));//随机字符串
data.setvalue("device_info", json.device_info);//终端ip
data.setvalue("openid", json.openid);
data.setvalue("check_name", json.check_name);
data.setvalue("re_user_name", json.re_user_name);
data.setvalue("amount", json.amount);
data.setvalue("desc", json.desc);
data.setvalue("sign", data.makesign(accountinfo.payapikey));//最后生成签名
var url = string.format("https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers");
return helper.getpayresultwithcert<corppayresult>(data, url, accountinfo.certpath, accountinfo.certpassword);
}
接口定义及实现好后,我们可以在项目中对api进行调用测试,具体代码如下所示
corppayjson json = new corppayjson()
{
amount = 100,
check_name = paycheckname.force_check.tostring(),
desc = "测试退款",
openid = this.openid,
device_info = "",
re_user_name = "伍华聪",
spbill_create_ip = networkutil.getipaddress()
};
var result = api.corppay(json);
var message = string.format("企业直接付款:{0} {1}", result.success ? "成功" : "失败", result.message);
console.writeline(message);
console.writeline(result.tojson());
付款操作成功后,我们可以看到这个钱是直接到用户钱包里面去的,而且我们也可以在商户后台进行记录的查看,可以看到对应的记录。
更多c#开发微信门户及应用微信支付之企业付款封装操作。