交易请求报文

  1. <?xml version="1.0" encoding="GBK"?>
  2. <business_trans>
  3. <request_type>scanpay_jsapi_request</request_type>
  4. <isspid>39493002</isspid>
  5. <pos_id>1511300001</pos_id>
  6. <store_id>1511300001</store_id>
  7. <pos_seq>1511300000002</pos_seq>
  8. <user_id>user01</user_id>
  9. <system_id>8888</system_id>
  10. <device_ip>127.0.0.1</device_ip>
  11. <scanpay_jsapi_request>
  12. <pay_type>502</pay_type>
  13. <tx_amt>1</tx_amt>
  14. <buyer_id>2088************</buyer_id>
  15. <notify_url><![CDATA[http://www.baidu.com/]]></notify_url>
  16. <extend_params><![CDATA[扩展参数]]></extend_params>
  17. <use_coupon>1</use_coupon>
  18. </scanpay_jsapi_request>
  19. </business_trans>

交易请求报文说明

节点名称中文名称类型说明是否必填
request_type请求类型String(32)标识请求报文的类型,固定为scanpay_jsapi_request必填
isspid商户号String(8)接入SP的ID号,由翼码平台分配给ipos接入受理商户的机构号(原值返回)必填
pos_id终端号String(20)终端号必填
store_id门店号String(20)门店号必填
pos_seq终端流水号String(32)同一个商户必须唯一,且大于12位必填
user_id操作员标识String(20)操作员号可空
system_id系统平台号String(4)由翼码提供必填
device_ip设备IPString(15)发起交易的门店公网IP
根据央行要求必须传门店真实公网IP
否则商家会被风控!!!
可空
scanpay_jsapi_request
->pay_type
支付类型String(3)502:支付宝支付
503:微信支付
必填
scanpay_jsapi_request
->buyer_id
用户标识String(128)支付宝:买家的支付宝唯一用户号(2088开头的16位纯数字)
微信:用户在商户appid下的唯一标识(openid)
必填
scanpay_jsapi_request
->tx_amt
交易金额Number(9)支付金额,单位为分,不支持小数点必填
scanpay_jsapi_request
->notify_url
异步通知地址String(256)通知地址建议使用CDATA标签包裹内容
异步通知文档见4.19
可空
scanpay_jsapi_request
->extend_params
扩展参数String用于扩展一些特殊的支付参数字段,以JSON格式传入
XML报文若传入信息带特殊字符请使用CDATA标签包裹内容
详细参数见下表
可空
scanpay_jsapi_request
->use_coupon
是否使用优惠券String(1)0:不使用优惠
1:可使用优惠
传空默认为1
具体应用:
a.微信可使用优惠时,翼码传送已配置的订单优惠标记(goods_tag)给微信
b.支付宝不可使用优惠时,翼码将不参与优惠计算的金额(undiscountable_amount)取订单金额传送给支付宝
可空

extend_params 扩展参数 (JSON)

JSON节点类型说明是否必填范例
hb_fq_numString花呗分期数,仅支持传入3、6、12,其他期数暂不支持
仅支付宝时生效
hb_fq_num与hb_fq_seller_percent必须同时传入且使用花呗分期商品明细必传
可空3
hb_fq_seller_percentString花呗卖家承担收费比例,商家承担手续费传入100,用户承担手续费传入0,仅支持传入100、0两种,其他比例暂不支持
仅支付宝时生效
hb_fq_num与hb_fq_seller_percent必须同时传入且使用花呗分期商品明细必传
可空100
split_flagString分账标识
N:不分账
R:实时分账
D:延时分账
不传该节点时,将按控制台配置处理
该节点与分账功能相关具体联系业务确认开通功能
可空R
split_infoJSON分账信息
仅支持请求实时分账split_flag=R
该节点与分账功能相关具体联系业务确认开通功能
可空 

分账业务相关的特别说明:
1. split_flag=N 不分账时,split_info不允许传入;
2. split_flag=R 实时分账时,split_info必传,其中keep_amt与div_amt叠加必须全额分完整笔订单;
3. split_flag=D 延时分账时,split_info不允许传入,在后续流程中调用延迟交易确认接口完成分账,或使用翼码分账系统界面进行分账。

split_info 分账信息

JSON节点类型说明是否必填范例
keep_amtString分账方自留金额,单位为分,可传0表示不自留必填1000
split_listArray分账明细必填 
split_list 分账明细
JSON节点类型说明是否必填范例
merchant_idString分账接收方的分账商户号必填10000000000001
div_amtString分账金额,单位为分,必须大于0必填1000

extend_params 样例:

  1. {
  2. "hb_fq_num": "3",
  3. "hb_fq_seller_percent": "100",
  4. "split_flag": "R",
  5. "split_info": {
  6. "keep_amt": "800",
  7. "split_list": [
  8. {
  9. "merchant_id": "10000000000001",
  10. "div_amt": "150"
  11. },
  12. {
  13. "merchant_id": "10000000000002",
  14. "div_amt": "50"
  15. }
  16. ]
  17. }
  18. }

交易返回报文

  1. <?xml version="1.0" encoding="GBK"?>
  2. <business_trans>
  3. <response_type>scanpay_jsapi_response</response_type>
  4. <isspid>39493002</isspid>
  5. <pos_id>1511300001</pos_id>
  6. <pos_seq>1511300000002</pos_seq>
  7. <sys_seq>0311095321465179</sys_seq>
  8. <trans_time>20160311095321</trans_time>
  9. <pay_type>502</pay_type>
  10. <pay_id>************************</pay_id>
  11. <result>
  12. <id>9998</id>
  13. <comment>下单成功,等待用户支付</comment>
  14. </result>
  15. </business_trans>

交易返回报文说明

标准接口会因业务升级需要而新增节点,请在解析返回报文时避免新增未知节点产生的程序出错!

节点名称中文名称类型说明是否必填
response_type返回类型String(32)标识返回报文的类型,固定为scanpay_jsapi_response必填
isspid商户号String(8)接入SP的ID号,为翼码平台的提供的业务商机构号必填
pos_id终端号String(20)终端号必填
pos_seq终端流水号String(32)终端交易流水号,和请求报文中的交易流水号相同必填
sys_seq平台流水号String(16)由翼码平台产生,供跟踪之用必填
trans_time交易时间String(14)交易时间,格式:yyyyMMddHHmmss必填
pay_type支付类型String(3)502:支付宝支付
503:微信支付
必填
pay_id交易标识idString(64)支付宝:支付宝交易号(trade_no)
微信:微信生成的预支付回话标识(prepay_id)
用于调用H5支付页面
下单成功时必填
可选
result->id响应码String(4)9998 - 下单成功等待用户支付,需调用查询接口确认交易
其它失败,错误信息说明见“响应码解释”字段
必填
result->comment响应码解释String(64)响应码对应中文注解,用于显示提示必填

标准接口会因业务升级需要而新增节点,请在解析返回报文时避免新增未知节点产生的程序出错!

跳转H5支付页面的方法

跳转H5支付页面:http://zctest.imageco.cn/iss2_ipos/Web/jsapi_pay.php

请求方式:GET

中文字符编码:UTF-8

请求参数:

参数名中文名称说明是否必填
pay_id交易标识idJSAPI支付接口下单成功之后返回的参数(pay_id)必填
subject收款页标题在支付页面展示的标题必填
show_url回调Url支付成功之后回调的Url必填
payee收款方名称不传默认取商户在翼码系统的商户名称可空

参数名注意大小写,严格区分大小写,参数值注意使用urlencode处理。

调用范例:

  1. http://zctest.imageco.cn/iss2_ipos/Web/jsapi_pay.php?pay_id=2018122923011429700544283355&subject=%e6%94%b6%e6%ac%be%e6%a0%87%e9%a2%98&show_url=https%3a%2f%2fopen.wangcaio2o.com%3faaa%3d1%26bbb%3d%e5%95%8a%e5%95%8a%e5%95%8a&payee=%E6%94%B6%E6%AC%BE%E6%96%B9%E5%90%8D%E7%A7%B0

页面范例:

JSAPI支付交易 - 图1