chengkun
2025-06-05 4080b5997b38ca84b3b203c7101dcadb97b76925
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
// 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;
 
 
namespace Alipay.EasySDK.Util.AES
{
    public class Client 
    {
        protected Alipay.EasySDK.Kernel.Client _kernel;
 
        public Client(Alipay.EasySDK.Kernel.Client kernel)
        {
            this._kernel = kernel;
        }
 
 
        public string Decrypt(string cipherText)
        {
            return this._kernel.AesDecrypt(cipherText, this._kernel.GetConfig("encryptKey"));
        }
 
        public string Encrypt(string plainText)
        {
            return this._kernel.AesEncrypt(plainText, this._kernel.GetConfig("encryptKey"));
        }
 
        
        /// <summary>
        /// ISV代商户代用,指定appAuthToken
        /// </summary>
        /// <param name="appAuthToken">代调用token</param>
        /// <returns>本客户端,便于链式调用</returns>
        public Client Agent(string appAuthToken)
        {
            _kernel.InjectTextParam("app_auth_token", appAuthToken);
            return this;
        }
 
        /// <summary>
        /// 用户授权调用,指定authToken
        /// </summary>
        /// <param name="authToken">用户授权token</param>
        /// <returns>本客户端,便于链式调用</returns>
        public Client Auth(string authToken)
        {
            _kernel.InjectTextParam("auth_token", authToken);
            return this;
        }
 
        /// <summary>
        /// 设置异步通知回调地址,此处设置将在本调用中覆盖Config中的全局配置
        /// </summary>
        /// <param name="url">异步通知回调地址,例如:https://www.test.com/callback </param>
        /// <returns>本客户端,便于链式调用</returns>
        public Client AsyncNotify(string url)
        {
            _kernel.InjectTextParam("notify_url", url);
            return this;
        }
 
        /// <summary>
        /// 将本次调用强制路由到后端系统的测试地址上,常用于线下环境内外联调,沙箱与线上环境设置无效
        /// </summary>
        /// <param name="testUrl">后端系统测试地址</param>
        /// <returns>本客户端,便于链式调用</returns>
        public Client Route(string testUrl)
        {
            _kernel.InjectTextParam("ws_service_url", testUrl);
            return this;
        }
 
        /// <summary>
        /// 设置API入参中没有的其他可选业务请求参数(biz_content下的字段)
        /// </summary>
        /// <param name="key">业务请求参数名称(biz_content下的字段名,比如timeout_express)</param>
        /// <param name="value">
        /// 业务请求参数的值,一个可以序列化成JSON的对象
        /// 如果该字段是一个字符串类型(String、Price、Date在SDK中都是字符串),请使用string储存
        /// 如果该字段是一个数值型类型(比如:Number),请使用long储存
        /// 如果该字段是一个复杂类型,请使用嵌套的Dictionary指定各下级字段的值
        /// 如果该字段是一个数组,请使用List储存各个值
        /// 对于更复杂的情况,也支持Dictionary和List的各种组合嵌套,比如参数是值是个List,List中的每种类型是一个复杂对象
        /// </param>
        /// <returns>本客户端,便于链式调用</returns>
        public Client Optional(string key, object value)
        {
            _kernel.InjectBizParam(key, value);
            return this;
        }
 
        /// <summary>
        /// 批量设置API入参中没有的其他可选业务请求参数(biz_content下的字段)
        /// optional方法的批量版本
        /// </summary>
        /// <param name="optionalArgs">可选参数集合,每个参数由key和value组成,key和value的格式请参见optional方法的注释</param>
        /// <returns>本客户端,便于链式调用</returns>
        public Client BatchOptional(Dictionary<string, object> optionalArgs)
        {
            foreach (var pair in optionalArgs)
            {
                _kernel.InjectBizParam(pair.Key, pair.Value);
            }
            return this;
        }
    }
}