ホームページ  >  記事  >  WeChat アプレット  >  C# は WeChat ポータルを開発し、WeChat 決済エンタープライズ決済パッケージング操作を適用します。

C# は WeChat ポータルを開発し、WeChat 決済エンタープライズ決済パッケージング操作を適用します。

高洛峰
高洛峰オリジナル
2017-03-07 09:41:422782ブラウズ

1. 法人決済のご紹介

いわゆる法人決済とは、機能オープン後のお客様からのクレーム、返却、商品の返金、回収活動の特典の配布、抽選のやりとりなどの業務を指します。保険業界におけるすべての手続きは、法人支払い完了を通じて行うことができます。以前は、WeChat Pay は顧客に対し企業への一方向の支払いしか提供できませんでした。

販売者がユーザーに支払う必要がある場合、ユーザーの「WeChat 変更」に直接送金することができ、WeChat Pay は変更をユーザーに通知し、変更の受領書と支出の詳細に対応する記録が表示されます。変更アカウントのない履歴クライアント バージョンの場合、資金はユーザーの赤い封筒アカウントに転送されます。WeChat Pay からユーザーに通知するメッセージはなく、企業は独自にユーザーに連絡することを選択できます。

認定されたエンタープライズ アカウントは、WeChat 支払い機能を有効にすることができます。認証されたエンタープライズアカウントは、管理プラットフォームの「サービスセンター」の「WeChat Payment」ポータルでWeChat決済機能を申請できます。 WeChat の支払い機能を開設すると、エンタープライズ アカウントには回収と支払いの 2 つの機能が追加されます。ユーザー アカウントからエンタープライズ アカウントに支払いが行われた場合、そのお金はエンタープライズ アカウントに関連付けられたマーチャント アカウントに送られます。同時に、企業アカウントは、WeChat 赤い封筒または WeChat 転送を通じてユーザー アカウントに支払うことができます。

エンタープライズペイメントは、企業がユーザーに支払いを行う機能を提供し、企業が API インターフェイスを介して支払いを行ったり、WeChat Pay 加盟店プラットフォームの Web 機能を介して支払いを操作したりすることをサポートします。

ファンド運営に関わる機能には高度なセキュリティ要件があり、オペレーターは証明書(マーチャントプラットフォーム-アカウント設定-パスワードセキュリティ-操作証明書)をインストールし、APIまたはWebページを通じて操作し、対象ユーザーに支払いを行う必要があります(企業はそれに応じて操作できます)。 APPID+OpenID 対象ユーザーに)。 WeChat Payでは、実名認証を行っているユーザーに対して、実名の一致性を検証するオプション機能を提供できます。

エンタープライズ支払いのヒント:

◆ 同じ実名ユーザーへの支払いの場合、1 日あたりの 1 回の制限は 2W/2W です

◆ 同じ非実名ユーザーへの支払いの場合、1 回の 1 日の制限は 2000 /2000

◆ 加盟店 当日の総支払限度額は100W

◆ 加盟店アカウントに紐付けられたAPPIDのみ対応

◆ 決済対象者はWeChatで認証されたユーザーとなります。実名支払いは実名を認証する機能を提供し、認証されていないユーザーは認証できません。企業は自社のセキュリティレベルに応じて認証タイプを選択できます

◆支払い額は以下でなければなりません。または加盟店の現在の利用可能残高と同等の金額。

◆支払い記録については、企業は企業支払いクエリを通じて対応するデータを表示できます。

C# は WeChat ポータルを開発し、WeChat 決済エンタープライズ決済パッケージング操作を適用します。

2. エンタープライズ決済 API

エンタープライズ決済ビジネスは、開発中の一部の加盟店向けに、WeChat 決済加盟店プラットフォームの資金管理機能に基づいています。機能、API が提供されており、法人決済機能を完備します。

たとえば、現在の保険業界は、保険契約を解約し、保険金を支払い、顧客に請求を解決します。


エンタープライズ支払いでは販売者の利用可能残高が使用され、利用可能残高が十分であることを確認する必要があります。利用可能残高の確認、チャージ、出金を行うには、加盟店プラットフォームの「資金管理」にログインして操作してください。


インターフェースアドレス


インターフェースリンク: https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers


はい証明書が必要です


リクエストには双方向の証明書が必要です。 証明書の詳細な使用方法

リクエスト パラメーター

C# は WeChat ポータルを開発し、WeChat 決済エンタープライズ決済パッケージング操作を適用します。 送信されたデータの例:

<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# を構築できます。コードインターフェイス

C# は WeChat ポータルを開発し、WeChat 決済エンタープライズ決済パッケージング操作を適用します。上記のインターフェイス定義によれば、次のようにインターフェイス情報を定義できます

/// <summary>
    /// 微信支付接口
    /// </summary>
    public interface ITenPayApi
    {  

        /// <summary>
        /// 企业付款(请求需要双向证书)
        /// 企业付款业务是基于微信支付商户平台的资金管理能力,为了协助商户方便地实现企业向个人付款,
        /// 针对部分有开发能力的商户,提供通过API完成企业付款的功能。 比如目前的保险行业向客户退保、给付、理赔。
        /// 企业付款将使用商户的可用余额,需确保可用余额充足。查看可用余额、充值、提现请登录商户平台“资金管理”进行操作。https://pay.weixin.qq.com/ 
        /// 注意:与商户微信支付收款资金并非同一账户,需要单独充值。
        /// </summary>
        /// <param>企业支付数据
        /// <returns></returns>
        CorpPayResult CorpPay(CorpPayJson json);

        ..............

上記のCorpPayJsonとCorpPayResultは、それぞれ受信パラメータと取得した結果の内容であり、オブジェクト情報です2 つはパラメータに基づいて定義するだけです。

/// <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>企业支付数据
        /// <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);
        }</corppayresult>

接口定义及实现好后,我们可以在项目中对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# は WeChat ポータルを開発し、WeChat 決済エンタープライズ決済パッケージング操作を適用します。

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

C# は WeChat ポータルを開発し、WeChat 決済エンタープライズ決済パッケージング操作を適用します。

 

 更多C# は WeChat ポータルを開発し、WeChat 決済エンタープライズ決済パッケージング操作を適用します。相关文章请关注PHP中文网!

 

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。