using System.ComponentModel.DataAnnotations; using Newtonsoft.Json; using Newtonsoft.Json.Serialization; namespace PaySharp.Alipay.Domain { /// /// 支付基础模型 /// 目前仅适用于App,Web,Wap /// [JsonObject(NamingStrategyType = typeof(SnakeCaseNamingStrategy))] public class BasePayModel { /// /// 构造函数 /// /// 销售产品码 public BasePayModel(string productCode) { ProductCode = productCode; } /// /// 商户订单号,64个字符以内、可包含字母、数字、下划线;需保证在商户端不重复 /// [StringLength(64, ErrorMessage = "商户订单号最大长度为64位")] [Required(ErrorMessage = "请设置商户订单号")] public string OutTradeNo { get; set; } /// /// 销售产品码,与支付宝签约的产品码名称。 /// public string ProductCode { get; private set; } /// /// 订单总金额,单位为元 /// [Required(ErrorMessage = "请设置订单总金额")] public double TotalAmount { get; set; } /// /// 订单标题 /// [StringLength(256, ErrorMessage = "订单标题最大长度为256位")] [Required(ErrorMessage = "请设置订单标题")] public string Subject { get; set; } /// /// 订单描述 /// [StringLength(128, ErrorMessage = "商户订单号最大长度为128位")] public string Body { get; set; } /// /// 业务扩展参数,详见业务扩展参数说明 https://docs.open.alipay.com/#kzcs /// public ExtendParam ExtendParams { get; set; } /// /// 该笔订单允许的最晚付款时间,逾期将关闭交易。 /// 取值范围:1m~15d。m-分钟,h-小时,d-天,1c-当天(1c-当天的情况下,无论交易何时创建,都在0点关闭)。 /// 该参数数值不接受小数点, 如 1.5h,可转换为 90m。该参数在请求到支付宝时开始计时。 /// [StringLength(6, ErrorMessage = "该笔订单允许的最晚付款时间最大长度为6位")] public string TimeoutExpress { get; set; } /// /// 公用回传参数,如果请求时传递了该参数,则返回给商户时会回传该参数。 /// 支付宝只会在异步通知时将该参数原样返回。本参数必须进行UrlEncode之后才可以发送给支付宝 /// [StringLength(512, ErrorMessage = "公用回传参数最大长度为512位")] public string PassbackParams { get; set; } /// /// 商品主类型:0—虚拟类商品,1—实物类商品(默认 /// 注:虚拟类商品不支持使用花呗渠道 /// [Range(0, 1, ErrorMessage = "商品主类型只能为0或1")] public int GoodsType { get; set; } /// /// 绝对超时时间,格式为yyyy-MM-dd HH:mm。 /// 注:1)以支付宝系统时间为准;2)如果和timeout_express参数同时传入,以time_expire为准。 /// [StringLength(32, ErrorMessage = "绝对超时时间最大长度为32位")] public string TimeExpire { get; set; } /// /// 可用渠道,用户只能在指定渠道范围内支付,当有多个渠道时用“,”分隔 /// 注:与disable_pay_channels互斥 https://docs.open.alipay.com/#qdsm /// [StringLength(128, ErrorMessage = "可用渠道最大长度为128位")] public string EnablePayChannels { get; set; } /// /// 禁用渠道,用户不可用指定渠道支付,当有多个渠道时用“,”分隔 /// 注:与enable_pay_channels互斥 https://docs.open.alipay.com/#qdsm /// [StringLength(128, ErrorMessage = "禁用渠道最大长度为128位")] public string DisablePayChannels { get; set; } /// /// 优惠参数 注:仅与支付宝协商后可用 /// [StringLength(512, ErrorMessage = "优惠参数最大长度为512位")] public string PromoParams { get; set; } /// /// 商户门店编号。该参数用于请求参数中以区分各门店,非必传项。 /// [StringLength(32, ErrorMessage = "商户门店编号最大长度为32位")] public string StoreId { get; set; } /// /// 外部指定买家,详见外部用户ExtUserInfo参数说明 https://docs.open.alipay.com/#wbsh /// public ExtUserInfo ExtUserInfo { get; set; } } }