All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.binarywang.wxpay.bean.request.WxPayMicropayRequest Maven / Gradle / Ivy

package com.github.binarywang.wxpay.bean.request;

import com.thoughtworks.xstream.annotations.XStreamAlias;
import lombok.*;
import me.chanjar.weixin.common.annotation.Required;

import java.util.Map;

/**
 * 
 *  提交付款码支付请求对象类
 * Created by Binary Wang on 2017-3-23.
 * 
* * @author Binary Wang */ @Data @EqualsAndHashCode(callSuper = true) @Builder(builderMethodName = "newBuilder") @NoArgsConstructor @AllArgsConstructor @XStreamAlias("xml") public class WxPayMicropayRequest extends BaseWxPayRequest { private static final long serialVersionUID = 100577773033376092L; /** *
   * 字段名:设备号.
   * 变量名:device_info
   * 是否必填:否
   * 类型:String(32)
   * 示例值:013467007045764
   * 描述:终端设备号(商户自定义,如门店编号)
   * 
*/ @XStreamAlias("device_info") private String deviceInfo; /** *
   * 字段名:接口版本号.
   * 变量名:version
   * 是否必填:单品优惠必填
   * 类型:String(32)
   * 示例值:1.0
   * 描述:单品优惠新增字段,区分原接口,固定填写1.0
   * 更多信息,详见文档:https://pay.weixin.qq.com/wiki/doc/api/danpin.php?chapter=9_101&index=1
   * 
*/ @XStreamAlias("version") private String version; /** *
   * 字段名:商品描述.
   * 变量名:body
   * 是否必填:是
   * 类型:String(128)
   * 示例值:image形象店-深圳腾大- QQ公仔
   * 描述:商品简单描述,该字段须严格按照规范传递,具体请见参数规定
   * 
**/ @Required @XStreamAlias("body") private String body; /** *
   * 字段名:商品详情.
   * 变量名:detail
   * 是否必填:否
   * 类型:String(6000)
   * 示例值:
   * 描述:单品优惠功能字段,需要接入请见详细说明
**/ @XStreamAlias("detail") private String detail; /** *
   * 字段名:附加数据.
   * 变量名:attach
   * 是否必填:否
   * 类型:String(127)
   * 示例值:说明
   * 描述:附加数据,在查询API和支付通知中原样返回,该字段主要用于商户携带订单的自定义数据
   * 
**/ @XStreamAlias("attach") private String attach; /** *
   * 字段名:商户订单号.
   * 变量名:out_trade_no
   * 是否必填:是
   * 类型:String(32)
   * 示例值:1217752501201407033233368018
   * 描述:商户系统内部的订单号,32个字符内、可包含字母,其他说明见商户订单号
   * 
**/ @Required @XStreamAlias("out_trade_no") private String outTradeNo; /** *
   * 字段名:订单金额.
   * 变量名:total_fee
   * 是否必填:是
   * 类型:Int
   * 示例值:888
   * 描述:订单总金额,单位为分,只能为整数,详见支付金额
   * 
**/ @Required @XStreamAlias("total_fee") private Integer totalFee; /** *
   * 字段名:货币类型.
   * 变量名:fee_type
   * 是否必填:否
   * 类型:String(16)
   * 示例值:CNY
   * 描述:符合ISO4217标准的三位字母代码,默认人民币:CNY,其他值列表详见货币类型
   * 
**/ @XStreamAlias("fee_type") private String feeType; /** *
   * 字段名:终端IP.
   * 变量名:spbill_create_ip
   * 是否必填:是
   * 类型:String(16)
   * 示例值:8.8.8.8
   * 描述:调用微信支付API的机器IP
   * 
**/ @Required @XStreamAlias("spbill_create_ip") private String spbillCreateIp; /** *
   * 字段名:商品标记.
   * 变量名:goods_tag
   * 是否必填:否
   * 类型:String(32)
   * 示例值:1234
   * 描述:商品标记,代金券或立减优惠功能的参数,说明详见代金券或立减优惠
   * 
**/ @XStreamAlias("goods_tag") private String goodsTag; /** *
   * 字段名:指定支付方式.
   * 变量名:limit_pay
   * 是否必填:否
   * 类型:String(32)
   * 示例值:no_credit
   * 描述:no_credit--指定不能使用信用卡支付
   * 
**/ @XStreamAlias("limit_pay") private String limitPay; /** *
   * 字段名:交易起始时间.
   * 变量名:time_start
   * 是否必填:否
   * 类型:String(14)
   * 示例值:20091225091010
   * 描述:订单生成时间,格式为yyyyMMddHHmmss,如2009年12月25日9点10分10秒表示为20091225091010。其他详见时间规则
   * 
*/ @XStreamAlias("time_start") private String timeStart; /** *
   * 字段名:交易结束时间.
   * 变量名:time_expire
   * 是否必填:否
   * 类型:String(14)
   * 示例值:20091227091010
   * 描述:订单失效时间,格式为yyyyMMddHHmmss,如2009年12月27日9点10分10秒表示为20091227091010。其他详见时间规则
   * 注意:最短失效时间间隔必须大于5分钟
   * 
*/ @XStreamAlias("time_expire") private String timeExpire; /** *
   * 字段名:电子发票入口开放标识	.
   * 变量名:receipt
   * 是否必填:否
   * 类型:String(8)
   * 示例值:Y
   * 描述:Y,传入Y时,支付成功消息和支付详情页将出现开票入口。需要在微信支付商户平台或微信公众平台开通电子发票功能,传此字段才可生效
   * 
**/ @XStreamAlias("receipt") private String receipt; /** *
   * 字段名:授权码.
   * 变量名:auth_code
   * 是否必填:是
   * 类型:String(128)
   * 示例值:120061098828009406
   * 描述:扫码支付授权码,设备读取用户微信中的条码或者二维码信息注:用户刷卡条形码规则:18位纯数字,以10、11、12、13、14、15开头)
   * 
**/ @Required @XStreamAlias("auth_code") private String authCode; /** *
   * 字段名:场景信息.
   * 变量名:scene_info
   * 是否必填:否
   * 类型:String(256)
   * 示例值:{"store_info" : {
   * "id": "SZTX001",
   * "name": "腾大餐厅",
   * "area_code": "440305",
   * "address": "科技园中一路腾讯大厦" }}
   * 描述:该字段用于上报场景信息,目前支持上报实际门店信息。该字段为JSON对象数据,对象格式为{"store_info":{"id": "门店ID","name": "名称","area_code": "编码","address": "地址" }}
   * 
*/ @XStreamAlias("scene_info") private String sceneInfo; /** *
   * 字段名:是否指定服务商分账.
   * 变量名:profit_sharing
   * 是否必填:否
   * 详情:Y-是,需要分账  N-否,不分账,字母要求大写,不传默认不分账
   * 详细参考 https://pay.weixin.qq.com/wiki/doc/api/allocation_sl.php?chapter=24_3&index=3
   * 
*/ @XStreamAlias("profit_sharing") private String profitSharing; @Override protected void checkConstraints() { //do nothing } @Override protected void storeMap(Map map) { map.put("version", version); map.put("body", body); map.put("detail", detail); map.put("attach", attach); map.put("out_trade_no", outTradeNo); map.put("total_fee", totalFee.toString()); map.put("fee_type", feeType); map.put("spbill_create_ip", spbillCreateIp); map.put("goods_tag", goodsTag); map.put("limit_pay", limitPay); map.put("time_start", timeStart); map.put("time_expire", timeExpire); map.put("auth_code", authCode); map.put("scene_info", sceneInfo); map.put("profit_sharing",profitSharing); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy