V2MerchantBasicdataEntRequestDemo.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. using System;
  2. using System.Collections.Generic;
  3. using BasePaySdk;
  4. using BasePaySdk.Request;
  5. using Newtonsoft.Json;
  6. using Newtonsoft.Json.Linq;
  7. namespace BasePayDemo
  8. {
  9. /**
  10. * 企业商户基本信息入驻(2022) - 示例
  11. *
  12. * @author sdk-generator
  13. * @Description
  14. */
  15. public class V2MerchantBasicdataEntRequestDemo
  16. {
  17. public static void V2MerchantBasicdataEntRequestDemoTest()
  18. {
  19. // 1. 数据初始化
  20. InitMerConfig.init();
  21. // 2.组装请求参数
  22. V2MerchantBasicdataEntRequest request = new V2MerchantBasicdataEntRequest();
  23. // 请求流水号
  24. request.setReqSeqId(DateTime.Now.ToString("yyy-MM-dd HH.mm.ss.fff"));
  25. // 请求日期
  26. request.setReqDate(DateTime.Now.ToString("yyyyMMdd"));
  27. // 直属渠道号
  28. request.setUpperHuifuId("6666000003080000");
  29. // 商户名称
  30. request.setRegName("集成企业商户8664");
  31. // 商户简称
  32. request.setShortName("企业商户3471");
  33. // 公司类型
  34. request.setEntType("1");
  35. // 营业执照编号
  36. request.setLicenseCode("20220422267883697");
  37. // 营业执照有效期类型
  38. request.setLicenseValidityType("1");
  39. // 营业执照有效期开始日期
  40. request.setLicenseBeginDate("20200401");
  41. // 营业执照有效期截止日期日期格式:yyyyMMdd,以北京时间为准。<font color="green">示例值:20220125</font><br/> 当license_validity_type=0时必填 ;当license_validity_type=1时为空;当使用总部资质时不填
  42. request.setLicenseEndDate("");
  43. // 注册省
  44. request.setRegProvId("350000");
  45. // 注册市
  46. request.setRegAreaId("350200");
  47. // 注册区
  48. request.setRegDistrictId("350203");
  49. // 注册详细地址
  50. request.setRegDetail("吉林省长春市思明区解放2路59096852");
  51. // 法人姓名
  52. request.setLegalName("陈立二");
  53. // 法人证件类型
  54. request.setLegalCertType("00");
  55. // 法人证件号码
  56. request.setLegalCertNo("321084198912060000");
  57. // 法人证件有效期类型
  58. request.setLegalCertValidityType("1");
  59. // 法人证件有效期开始日期
  60. request.setLegalCertBeginDate("20121201");
  61. // 法人证件有效期截止日期日期格式:yyyyMMdd,以北京时间为准。 <font color="green">示例值:20220125</font><br/>当legal_cert_validity_type=0时必填 ;当legal_cert_validity_type=1时为空 ;当使用总部资质时不填
  62. request.setLegalCertEndDate("20301201");
  63. // 经营省
  64. request.setProvId("310000");
  65. // 经营市
  66. request.setAreaId("310100");
  67. // 经营区
  68. request.setDistrictId("310104");
  69. // 经营详细地址
  70. request.setDetailAddr("吉林省长春市思明区解放1路49227677");
  71. // 联系人姓名
  72. request.setContactName("联系人");
  73. // 联系人手机号
  74. request.setContactMobileNo("13111112222");
  75. // 联系人电子邮箱
  76. request.setContactEmail("jeff.peng@huifu.com");
  77. // 客服电话
  78. request.setServicePhone("021-121111221");
  79. // 经营类型
  80. request.setBusiType("1");
  81. // 小票名称
  82. request.setReceiptName("盈盈超市");
  83. // 所属行业
  84. request.setMcc("5411");
  85. // 结算卡信息配置
  86. request.setCardInfo(getCardInfo());
  87. // 基本存款账户编号或核准号基本存款账户信息请填写基本存款账户编号;开户许可证请填写核准号 ;<br/>当注册地址或经营地址为如下地区时必填:浙江,海南,重庆,河南,江苏,宁波市,黑龙江,吉林,湖南,贵州,陕西,湖北 <br/>当使用总部资质时不填 ;<font color="green">示例值:J2900123456789</font>
  88. request.setOpenLicenceNo("");
  89. // 总部汇付Id如果headOfficeFlag=0,useHeadInfoFlag=Y,且head_huifu_id不为空则基本信息部分复用总部的基本信息。<br/>如果head_office_flag=0,则字段必填,如果head_office_flag=1,总部汇付Id不可传<br/><font color="green">示例值:6666000123123123</font>
  90. // request.setHeadHuifuId("test");
  91. // 设置非必填字段
  92. Dictionary<string, object> extendInfoMap = getExtendInfos();
  93. request.setExtendInfo(extendInfoMap);
  94. try {
  95. // 3. 发起API调用
  96. // 调用接口,使用默认商户配置时可省略配置key
  97. Dictionary<string, Object> result = null;
  98. result = BasePayClient.postRequest(request,null);
  99. // 使用指定配置调用接口
  100. // result = BasePayClient.postRequest(request,null,"merchantKey2");
  101. Console.WriteLine(JsonConvert.SerializeObject(result));
  102. }
  103. catch (Exception ex) {
  104. Console.WriteLine(ex);
  105. }
  106. }
  107. /**
  108. * 非必填字段
  109. * @return
  110. */
  111. private static Dictionary<string, object> getExtendInfos() {
  112. // 设置非必填字段
  113. Dictionary<string, object> extendInfoMap = new Dictionary<string, object>();
  114. // 营业执照类型
  115. extendInfoMap.Add("license_type", "");
  116. // 商户通知标识
  117. extendInfoMap.Add("sms_send_flag", "Y");
  118. // 管理员账号
  119. extendInfoMap.Add("login_name", "LG20220422267883697");
  120. // 取现信息配置
  121. extendInfoMap.Add("cash_config", getCashConfig());
  122. // 结算规则配置
  123. extendInfoMap.Add("settle_config", getSettleConfig());
  124. // 异步请求地址
  125. extendInfoMap.Add("async_return_url", "virgo://http://192.168.85.157:30031/sspm/testVirgo");
  126. // D1结算协议
  127. extendInfoMap.Add("settle_agree_pic", "");
  128. // 商户英文名称
  129. extendInfoMap.Add("mer_en_name", "");
  130. // 商户主页URL
  131. extendInfoMap.Add("mer_url", "");
  132. // 商户ICP备案编号
  133. extendInfoMap.Add("mer_icp", "");
  134. // 签约人
  135. // extendInfoMap.Add("sign_user_info", getSignUserInfo());
  136. // 是否总部商户
  137. // extendInfoMap.Add("head_office_flag", "");
  138. // 使用总部资料
  139. // extendInfoMap.Add("use_head_info_flag", "");
  140. // 开户许可证
  141. // extendInfoMap.Add("reg_acct_pic", "");
  142. // 结算卡正面
  143. // extendInfoMap.Add("settle_card_front_pic", "");
  144. // 结算卡反面
  145. // extendInfoMap.Add("settle_card_back_pic", "");
  146. // 结算人身份证国徽面
  147. // extendInfoMap.Add("settle_cert_back_pic", "");
  148. // 结算人身份证人像面
  149. // extendInfoMap.Add("settle_cert_front_pic", "");
  150. // 税务登记证
  151. // extendInfoMap.Add("tax_reg_pic", "");
  152. // 法人身份证国徽面
  153. // extendInfoMap.Add("legal_cert_back_pic", "");
  154. // 法人身份证人像面
  155. // extendInfoMap.Add("legal_cert_front_pic", "");
  156. // 营业执照图片
  157. // extendInfoMap.Add("license_pic", "");
  158. // 授权委托书
  159. // extendInfoMap.Add("auth_enturst_pic", "");
  160. // 组织机构代码证
  161. // extendInfoMap.Add("org_code_pic", "");
  162. return extendInfoMap;
  163. }
  164. private static string getCardInfo() {
  165. Dictionary<string, object> obj = new Dictionary<string, object>();
  166. // 结算账户类型
  167. obj.Add("card_type", "1");
  168. // 结算账户名
  169. obj.Add("card_name", "陈立二");
  170. // 结算账号
  171. obj.Add("card_no", "6225682141000000000");
  172. // 银行所在省参考[地区编码](https://paas.huifu.com/open/doc/api/#/csfl/api_csfl_dqbm);&lt;font color&#x3D;&quot;green&quot;&gt;示例值:310000&lt;/font&gt;;如修改省市要级联修改&lt;br/&gt;当card_type&#x3D;0时非必填, 当card_type&#x3D;1或2时必填
  173. obj.Add("prov_id", "310000");
  174. // 银行所在市参考[地区编码](https://paas.huifu.com/open/doc/api/#/csfl/api_csfl_dqbm);&lt;font color&#x3D;&quot;green&quot;&gt;示例值:310100&lt;/font&gt;;如修改省市要级联修改&lt;br/&gt;当card_type&#x3D;0时非必填, 当card_type&#x3D;1或2时必填
  175. obj.Add("area_id", "310100");
  176. // 联行号参考:[银行支行编码](https://paas.huifu.com/open/doc/api/#/csfl/api_csfl_yhzhbm) 当card_type&#x3D;0时必填, 当card_type&#x3D;1或2时非必填 &lt;br/&gt;&lt;font color&#x3D;&quot;green&quot;&gt;示例值:102290026507&lt;/font&gt;
  177. obj.Add("branch_code", "103290040169");
  178. // 持卡人证件类型持卡人证件类型,参见《[自然人证件类型](https://paas.huifu.com/open/doc/api/#/api_ggcsbm?id&#x3D;%e8%87%aa%e7%84%b6%e4%ba%ba%e8%af%81%e4%bb%b6%e7%b1%bb%e5%9e%8b)》。&lt;br/&gt; 当card_type&#x3D;0时为空, 当card_type&#x3D;1或2时必填; &lt;font color&#x3D;&quot;green&quot;&gt;示例值:00&lt;/font&gt;
  179. obj.Add("cert_type", "00");
  180. // 持卡人证件有效期截止日期日期格式:yyyyMMdd,以北京时间为准。&lt;font color&#x3D;&quot;green&quot;&gt;示例值:20220125&lt;/font&gt;&lt;br/&gt; 当cert_validity_type&#x3D;0时必填;当cert_validity_type&#x3D;1时为空
  181. obj.Add("cert_end_date", "20301201");
  182. // 银行编码
  183. obj.Add("bank_code", "01030000");
  184. // 支行名称
  185. obj.Add("branch_name", "中国农业银行股份有限公司上海马当路支行");
  186. // 持卡人证件号码
  187. obj.Add("cert_no", "321084198912066000");
  188. // 持卡人证件有效期类型
  189. obj.Add("cert_validity_type", "1");
  190. // 持卡人证件有效期开始日期
  191. obj.Add("cert_begin_date", "20121201");
  192. // 结算人手机号
  193. obj.Add("mp", "13700000000");
  194. return JsonConvert.SerializeObject(obj);
  195. }
  196. private static string getCashConfig() {
  197. Dictionary<string, object> obj = new Dictionary<string, object>();
  198. // 取现固定手续费(元)fix_amt与fee_rate至少填写一项,单位元,需保留小数点后两位,不收费请填写0.00; &lt;font color&#x3D;&quot;green&quot;&gt;示例值:1.00&lt;/font&gt;
  199. obj.Add("fix_amt", "1.00");
  200. // 取现手续费率(%)fix_amt与fee_rate至少填写一项,单位%,需保留小数点后两位,取值范围[0.00,100.00],不收费请填写0.00;&lt;font color&#x3D;&quot;green&quot;&gt;示例值:0.05&lt;/font&gt;&lt;br/&gt;注:如果fix_amt与fee_rate都填写了则手续费&#x3D;fix_amt+支付金额*fee_rate
  201. obj.Add("fee_rate", "");
  202. // 取现类型
  203. obj.Add("cash_type", "D0");
  204. // 是否交易手续费外扣
  205. // obj.Add("out_fee_flag", "");
  206. // 手续费承担方
  207. // obj.Add("out_fee_huifu_id", "");
  208. // 交易手续费外扣的账户类型
  209. // obj.Add("out_fee_acct_type", "");
  210. JArray objList = new JArray();
  211. objList.Add(JToken.FromObject(obj));
  212. return JsonConvert.SerializeObject(objList);
  213. }
  214. private static string getSettleConfig() {
  215. Dictionary<string, object> obj = new Dictionary<string, object>();
  216. // 结算周期
  217. obj.Add("settle_cycle", "D1");
  218. // 结算手续费外扣商户号填写承担手续费的汇付商户号;当out_settle_flag&#x3D;1时必填,否则非必填;&lt;font color&#x3D;&quot;green&quot;&gt;示例值:6666000123123123&lt;/font&gt;
  219. obj.Add("out_settle_huifuid", "");
  220. // 起结金额
  221. obj.Add("min_amt", "1.00");
  222. // 留存金额
  223. obj.Add("remained_amt", "2.00");
  224. // 结算摘要
  225. obj.Add("settle_abstract", "abstract");
  226. // 手续费外扣标记
  227. obj.Add("out_settle_flag", "2");
  228. // 结算手续费外扣账户类型
  229. obj.Add("out_settle_acct_type", "");
  230. // 节假日结算手续费率(%)
  231. obj.Add("fixed_ratio", "5.00");
  232. // 结算方式
  233. obj.Add("settle_pattern", "");
  234. // 结算批次号
  235. obj.Add("settle_batch_no", "");
  236. // 是否优先到账
  237. obj.Add("is_priority_receipt", "");
  238. // 自定义结算处理时间
  239. obj.Add("settle_time", "");
  240. // 节假日结算手续费固定金额(元)
  241. // obj.Add("constant_amt", "");
  242. return JsonConvert.SerializeObject(obj);
  243. }
  244. private static string getSignUserInfo() {
  245. Dictionary<string, object> obj = new Dictionary<string, object>();
  246. // 签约人类型
  247. // obj.Add("type", "test");
  248. // 姓名
  249. // obj.Add("name", "");
  250. // 手机号
  251. // obj.Add("mobile_no", "");
  252. // 身份证
  253. // obj.Add("cert_no", "");
  254. // 身份证照片-人像面
  255. // obj.Add("identity_front_file_id", "");
  256. // 身份证照片-国徽面
  257. // obj.Add("identity_back_file_id", "");
  258. // 法人授权书
  259. // obj.Add("auth_file_id", "");
  260. return JsonConvert.SerializeObject(obj);
  261. }
  262. }
  263. }