// This file is auto-generated, don't edit it. Thanks. using System; using System.Collections; using System.Collections.Generic; using System.IO; using System.Threading.Tasks; using Tea; using Tea.Utils; using Alipay.EasySDK.Payment.Page.Models; namespace Alipay.EasySDK.Payment.Page { public class Client { protected Alipay.EasySDK.Kernel.Client _kernel; public Client(Alipay.EasySDK.Kernel.Client kernel) { this._kernel = kernel; } public AlipayTradePagePayResponse Pay(string subject, string outTradeNo, string totalAmount, string returnUrl) { Dictionary systemParams = new Dictionary { {"method", "alipay.trade.page.pay"}, {"app_id", this._kernel.GetConfig("appId")}, {"timestamp", this._kernel.GetTimestamp()}, {"format", "json"}, {"version", "1.0"}, {"alipay_sdk", this._kernel.GetSdkVersion()}, {"charset", "UTF-8"}, {"sign_type", this._kernel.GetConfig("signType")}, {"app_cert_sn", this._kernel.GetMerchantCertSN()}, {"alipay_root_cert_sn", this._kernel.GetAlipayRootCertSN()}, }; Dictionary bizParams = new Dictionary { {"subject", subject}, {"out_trade_no", outTradeNo}, {"total_amount", totalAmount}, {"product_code", "FAST_INSTANT_TRADE_PAY"}, }; Dictionary textParams = new Dictionary { {"return_url", returnUrl}, }; string sign = this._kernel.Sign(systemParams, bizParams, textParams, this._kernel.GetConfig("merchantPrivateKey")); Dictionary response = new Dictionary { {"body", this._kernel.GeneratePage("POST", systemParams, bizParams, textParams, sign)}, }; return TeaModel.ToObject(response); } /// /// ISV代商户代用,指定appAuthToken /// /// 代调用token /// 本客户端,便于链式调用 public Client Agent(string appAuthToken) { _kernel.InjectTextParam("app_auth_token", appAuthToken); return this; } /// /// 用户授权调用,指定authToken /// /// 用户授权token /// 本客户端,便于链式调用 public Client Auth(string authToken) { _kernel.InjectTextParam("auth_token", authToken); return this; } /// /// 设置异步通知回调地址,此处设置将在本调用中覆盖Config中的全局配置 /// /// 异步通知回调地址,例如:https://www.test.com/callback /// 本客户端,便于链式调用 public Client AsyncNotify(string url) { _kernel.InjectTextParam("notify_url", url); return this; } /// /// 将本次调用强制路由到后端系统的测试地址上,常用于线下环境内外联调,沙箱与线上环境设置无效 /// /// 后端系统测试地址 /// 本客户端,便于链式调用 public Client Route(string testUrl) { _kernel.InjectTextParam("ws_service_url", testUrl); return this; } /// /// 设置API入参中没有的其他可选业务请求参数(biz_content下的字段) /// /// 业务请求参数名称(biz_content下的字段名,比如timeout_express) /// /// 业务请求参数的值,一个可以序列化成JSON的对象 /// 如果该字段是一个字符串类型(String、Price、Date在SDK中都是字符串),请使用string储存 /// 如果该字段是一个数值型类型(比如:Number),请使用long储存 /// 如果该字段是一个复杂类型,请使用嵌套的Dictionary指定各下级字段的值 /// 如果该字段是一个数组,请使用List储存各个值 /// 对于更复杂的情况,也支持Dictionary和List的各种组合嵌套,比如参数是值是个List,List中的每种类型是一个复杂对象 /// /// 本客户端,便于链式调用 public Client Optional(string key, object value) { _kernel.InjectBizParam(key, value); return this; } /// /// 批量设置API入参中没有的其他可选业务请求参数(biz_content下的字段) /// optional方法的批量版本 /// /// 可选参数集合,每个参数由key和value组成,key和value的格式请参见optional方法的注释 /// 本客户端,便于链式调用 public Client BatchOptional(Dictionary optionalArgs) { foreach (var pair in optionalArgs) { _kernel.InjectBizParam(pair.Key, pair.Value); } return this; } } }