C#開發微信入口網站及應用微信支付之企業付款封裝操作

高洛峰
發布: 2017-03-07 09:41:42
原創
2742 人瀏覽過

1、企業付款的介紹

所謂企業付款指的是,在功能開放後諸如保險業的客戶理賠、退保、商品退款、發放徵集活動獎金、抽獎互動等操作都可以透過企業付款完成。而此前,微信支付只能提供客戶向企業單向付款。

商家如果需要給用戶付款,可以直接將錢打入用戶的「微信零錢」中,微信支付將做零錢入帳訊息通知,零錢收支明細會顯示相應記錄。針對無零錢帳戶的歷史用戶端版本,資金將進入用戶的紅包帳戶,微信支付無訊息通知用戶,企業可選擇自行觸達用戶。

通過認證的企業號可以開啟微信支付功能。通過認證的企業號可以管理平台的「服務中心」的「微信支付」入口裡進行微信支付功能申請。而開通微信支付功能後,企業號將有兩項功能:收款和付款。若是用戶號碼對企業號付款,款項將會進入企業號所關聯的商戶號碼。同時,企業號可以透過微信紅包或微信轉帳的形式對用戶號碼付款。

企業付款,提供企業向使用者付款的功能,支援企業透過API介面付款,或透過微信支付商家平台網頁功能操作付款。

涉及資金操作的功能,安全性需求較高,需要操作員安裝憑證(商家平台-帳戶設定-密碼安全-操作證書);透過API或網頁操作,付款至目標使用者(企業可根據APPID+OpenID鎖定目標用戶)。針對已實名認證的用戶,微信支付可提供校驗真實姓名一致性的選用功能。

企業付款小秘訣:

##    ◆ 給予同一個實名使用者付款,單筆單日限額2W/2W

    ◆ 給予同一個非實名用戶付款,單筆單日限額2000/2000

    ◆ 一個商戶同一日付款總額限額100W

    ◆僅支持商戶號已綁定的APPID;

    ◆針對付款的目標用戶,已微信支付實名認證的用戶可提供校驗真實姓名的功能,未實名認證的用戶無法校驗,企業可根據自身業務的安全級別選擇驗證類型;

    ◆付款金額必須小於或等於商家目前可用餘額的金額;

    ◆ 已付款的記錄,企業可透過企業付款查詢查看對應資料。

C#開發微信入口網站及應用微信支付之企業付款封裝操作

 

2、企業付款API

企業付款業務是基於微信支付商家平台的資金管理能力,為了協助商家方便地實現企業向個人付款,針對部分有開發能力的商戶,提供透過API完成企業付款的功能。 

例如目前的保險業向客戶退保、給付、理賠。

企業付款將使用商家的可用餘額,需確保可用餘額充足。查看可用餘額、儲值、提現請登入商家平台「資金管理」進行操作。


介面位址


介面連結:https:/ /api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers


##是否需要證書


C#開發微信入口網站及應用微信支付之企業付款封裝操作

C#開發微信入口網站及應用微信支付之企業付款封裝操作

C#開發微信入口網站及應用微信支付之企業付款封裝操作

#######請求需要雙向憑證。 詳見證書使用######請求參數###############提交資料範例:###
<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#開發微信入口網站及應用微信支付之企業付款封裝操作

付款操作成功后,我们可以看到这个钱是直接到用户钱包里面去的,而且我们也可以在商户后台进行记录的查看,可以看到对应的记录。

C#開發微信入口網站及應用微信支付之企業付款封裝操作

 

 更多C#開發微信入口網站及應用微信支付之企業付款封裝操作相关文章请关注PHP中文网!

 

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!