123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232 |
- using System;
- using System.Collections.Generic;
- using BasePaySdk;
- using BasePaySdk.Request;
- using Newtonsoft.Json;
- using Newtonsoft.Json.Linq;
- namespace BasePayDemo
- {
- /**
- * 微信特约商户进件 - 示例
- *
- * @author sdk-generator
- * @Description
- */
- public class V2MerchantDirectWechatSignRequestDemo
- {
- public static void V2MerchantDirectWechatSignRequestDemoTest()
- {
- // 1. 数据初始化
- InitMerConfig.init();
- // 2.组装请求参数
- V2MerchantDirectWechatSignRequest request = new V2MerchantDirectWechatSignRequest();
- // 请求流水号
- request.setReqSeqId(DateTime.Now.ToString("yyy-MM-dd HH.mm.ss.fff"));
- // 请求日期
- request.setReqDate(DateTime.Now.ToString("yyyyMMdd"));
- // 商户汇付Id
- request.setHuifuId("6666000003134509");
- // 渠道商汇付Id
- request.setUpperHuifuId("6666000003134508");
- // 开发者的应用ID
- request.setAppId("20200506780602902");
- // 商户号
- request.setMchId("748851385");
- // 经营者/法人是否为受益人
- request.setOwner("Y");
- // 超级管理员信息
- request.setContactInfo(getContactInfo());
- // 经营场景类型
- request.setSalesScenesType("SALES_SCENES_STORE,SALES_SCENES_MP,SALES_SCENES_MINI_PROGRAM,SALES_SCENES_WEB,SALES_SCENES_APP,SALES_SCENES_WEWORK");
- // 经营场景
- request.setSalesInfo(getSalesInfo());
- // 结算信息
- request.setSettlementInfo(getSettlementInfo());
- // 设置非必填字段
- Dictionary<string, object> extendInfoMap = getExtendInfos();
- request.setExtendInfo(extendInfoMap);
- try {
- // 3. 发起API调用
- // 调用接口,使用默认商户配置时可省略配置key
- Dictionary<string, Object> result = null;
- result = BasePayClient.postRequest(request,null);
- // 使用指定配置调用接口
- // result = BasePayClient.postRequest(request,null,"merchantKey2");
- Console.WriteLine(JsonConvert.SerializeObject(result));
- }
- catch (Exception ex) {
- Console.WriteLine(ex);
- }
- }
- /**
- * 非必填字段
- * @return
- */
- private static Dictionary<string, object> getExtendInfos() {
- // 设置非必填字段
- Dictionary<string, object> extendInfoMap = new Dictionary<string, object>();
- // 服务商微信公众号APPID对应密钥
- extendInfoMap.Add("wx_woa_secret", "1234567890");
- // 公司类型
- extendInfoMap.Add("ent_type", "2");
- // 登记证书
- extendInfoMap.Add("certificate_info", getCertificateInfo());
- // 最终受益人信息
- extendInfoMap.Add("ubo_info", getUboInfo());
- // 银行账户信息
- extendInfoMap.Add("bank_account_info", getBankAccountInfo());
- // 补充说明
- extendInfoMap.Add("business_addition_msg", "补充说明");
- // 文件列表
- extendInfoMap.Add("file_list", getFileList());
- return extendInfoMap;
- }
- private static string getContactInfo() {
- Dictionary<string, object> obj = new Dictionary<string, object>();
- // 超级管理员姓名
- obj.Add("contact_name", "超级管理员姓名7586");
- // 超级管理员证件号码<font color="green">示例值:320926198512025834</font><br/>1、“超级管理员证件号码”与“超级管理员微信openid”,二选一必填。<br/>2、超级管理员签约时,校验微信号绑定的银行卡实名信息,是否与该证件号码一致。<br/>3、可传身份证、来往内地通行证、来往大陆通行证、护照等证件号码。
- obj.Add("contact_cert_no", "530102198206242725");
- // 超级管理员微信openid<font color="green">示例值:oGhiSxIAPtEnPfe9Xo000000A</font><br/>1、“超级管理员身份证件号码”与“超级管理员微信openid”,二选一必填。<br/>2、超级管理员签约时,校验微信号是否与该微信openid一致。
- obj.Add("openid", "openid");
- // 超级管理员手机号
- obj.Add("contact_mobile_no", "13778851762");
- // 超级管理员电子邮箱
- obj.Add("contact_email", "89007865@qq.com");
- // 超级管理员证件类型
- obj.Add("cert_type", "00");
- return JsonConvert.SerializeObject(obj);
- }
- private static string getFileList() {
- Dictionary<string, object> obj = new Dictionary<string, object>();
- // 文件类型
- obj.Add("file_type", "F85");
- // 文件jfileID
- obj.Add("file_id", "42204258-967e-373c-88d2-1afa4c7bb8ef");
- // 文件名称
- obj.Add("file_name", "微信直连额外补充材料一");
- JArray objList = new JArray();
- objList.Add(JToken.FromObject(obj));
- return JsonConvert.SerializeObject(objList);
- }
- private static string getCertificateInfo() {
- Dictionary<string, object> obj = new Dictionary<string, object>();
- // 登记证书类型
- obj.Add("cert_type", "所有场景类型");
- // 证书号
- obj.Add("cert_no", "证书号");
- // 证书商户名称
- obj.Add("cert_mer_name", "证书商户名称");
- // 注册地址
- obj.Add("reg_detail", "注册地址");
- // 法人姓名
- obj.Add("legal_name", "法人姓名");
- // 证书有效期类型
- obj.Add("cert_validity_type", "1");
- // 证书有效期开始日期
- obj.Add("cert_begin_date", "20200420");
- // 文件列表
- // obj.Add("file_list", getFileList());
- // 证书有效期截止日期
- obj.Add("cert_end_date", "20400420");
- return JsonConvert.SerializeObject(obj);
- }
- private static string getUboInfo() {
- Dictionary<string, object> obj = new Dictionary<string, object>();
- // 证件类型
- obj.Add("cert_type", "00");
- // 证件号码
- obj.Add("cert_no", "530102198206242725");
- // 姓名
- obj.Add("name", "姓名");
- // 证件有效类型
- obj.Add("cert_validity_type", "1");
- // 证件有效期开始日期
- obj.Add("cert_begin_date", "20200420");
- // 文件列表
- obj.Add("file_list", getFileList());
- // 证件有效期截止日期
- obj.Add("cert_end_date", "20400420");
- return JsonConvert.SerializeObject(obj);
- }
- private static string getSalesInfo() {
- Dictionary<string, object> obj = new Dictionary<string, object>();
- // 服务商公众号APPID公众号场景必传(与mp_sub_appid二选一) 。可填写当前服务商商户号已绑定的公众号APPID。<font color="green">示例值:wx5934540532 </font>
- obj.Add("mp_appid", "服务商公众号APPID");
- // 商家公众号APPID公众号场景必传(与mp_appid二选一)。<font color="green">示例值:wx5934540532 </font> <br/>1、可填写与商家主体一致且已认证的公众号APPID,需是 已认证的服务号、政府或媒体类型的订阅号。<br/>2、审核通过后,系统将发起特约商家商户号与该AppID的 绑定(即配置为sub_appid),服务商随后可在发起支付时 选择传入该appid,以完成支付,并获取sub_openid用于数 据统计,营销等业务场景 。
- obj.Add("mp_sub_appid", "商家公众号APPID");
- // 服务商小程序APPID小程序场景必传(与mmini_program_sub_appid二选一)。 可填写当前服务商商户号已绑定的小程序APPID。<br/><font color="green">示例值:wx852a790f100000fe</font>
- obj.Add("mini_program_appid", "服务商小程序APPID");
- // 商家小程序APPID小程序场景必传(与mini_program_appid二选一),<font color="green">示例值:wx852a790f100000fe</font> <br/>1、可填写与商家主体一致且已认证的小程序APPID,需是 已认证的小程序。<br/> 2、审核通过后,系统将发起特约商家商户号与该AppID的 绑定(即配置为sub_appid),服务商随后可在发起支付时 选择传入该appid,以完成支付,并获取sub_openid用于数 据统计,营销等业务场景。
- obj.Add("mini_program_sub_appid", "商家小程序APPID");
- // 服务商应用APPIDAPP场景必传(与 app_sub_appid 二选一)。<font color="green">示例值:wx852a790f100000fe</font><br/> 可填写当前服务商商户号已绑定的应用APPID。
- obj.Add("app_appid", "服务商应用APPID");
- // 商家应用APPIDAPP场景必传(与app_appid二选一);<font color="green">示例值:wx852a790f100000fe</font> <br/>1、可填写与商家主体一致且已认证的应用APPID,需是已 认证的APP。 <br/>2、审核通过后,系统将发起特约商家商户号与该AppID的 绑定(即配置为sub_appid),服务商随后可在发起支付时 选择传入该appid,以完成支付,并获取sub_openid用于数 据统计,营销等业务场景。
- obj.Add("app_sub_appid", "商家应用APPID");
- // 文件列表
- obj.Add("file_list", getFileList());
- // 门店名称
- obj.Add("biz_store_name", "门店名称");
- // 门店省市编码
- obj.Add("biz_address_code", "门店省市编码");
- // 门店地址
- obj.Add("biz_store_address", "门店地址");
- // 线下场所对应的商家APPID
- obj.Add("biz_sub_appid", "线下场所对应的商家APPID");
- // 互联网网站域名
- obj.Add("domain", "互联网网站域名");
- // 互联网网站对应的商家APPID
- obj.Add("web_appid", "互联网网站对应的商家APPID");
- // 商家企业微信CorpID
- obj.Add("sub_corp_id", "商家企业微信CorpID");
- return JsonConvert.SerializeObject(obj);
- }
- private static string getSettlementInfo() {
- Dictionary<string, object> obj = new Dictionary<string, object>();
- // 入驻结算规则ID
- obj.Add("settlement_id", "716");
- // 所属行业
- obj.Add("qualification_type", "餐饮");
- // 文件列表
- obj.Add("file_list", getFileList());
- // 优惠费率活动ID
- obj.Add("activities_id", "20191030111cff5b5e");
- // 优惠费率活动值
- obj.Add("activities_rate", "0.60");
- return JsonConvert.SerializeObject(obj);
- }
- private static string getBankAccountInfo() {
- Dictionary<string, object> obj = new Dictionary<string, object>();
- // 账户类型
- obj.Add("bank_account_type", "BANK_ACCOUNT_TYPE_CORPORATE");
- // 开户名称
- obj.Add("account_name", "门店名称");
- // 开户银行
- obj.Add("account_bank", "中国农业银行");
- // 开户银行省市编码
- obj.Add("bank_address_code", "01030000");
- // 开户银行联行号1、17家直连银行无需填写,如为其他银行,则开户银行全称(含支行)和开户银行联行号二选一。<br/>2、详细参见[开户银行全称(含支行)对照表](https://pay.weixin.qq.com/wiki/doc/apiv3/terms_definition/chapter1_1_3.shtml#part-6)。<font color="green">示例值:102100020270</font>
- obj.Add("bank_branch_id", "102110001296");
- // 开户银行全称(含支行)1、17家直连银行无需填写,如为其他银行,则开户银行全称(含支行)和 开户银行联行号二选一。<br/>2、需填写银行全称,<font color="green">示例值:中国工商银行北京海运仓支行</font>,详细参见[开户银行全称(含支行)对照表](https://pay.weixin.qq.com/wiki/doc/apiv3/terms_definition/chapter1_1_3.shtml#part-6)。
- obj.Add("bank_name", "102110001296");
- // 银行账号
- obj.Add("account_number", "102110001296");
- return JsonConvert.SerializeObject(obj);
- }
- }
- }
|