当前位置: 首页>>代码示例>>C#>>正文


C# RestClient.ExecuteWithPolicyAsync方法代码示例

本文整理汇总了C#中RestClient.ExecuteWithPolicyAsync方法的典型用法代码示例。如果您正苦于以下问题:C# RestClient.ExecuteWithPolicyAsync方法的具体用法?C# RestClient.ExecuteWithPolicyAsync怎么用?C# RestClient.ExecuteWithPolicyAsync使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在RestClient的用法示例。


在下文中一共展示了RestClient.ExecuteWithPolicyAsync方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: LoginAsync

        /// <summary>
        /// Authenticate this client with the Zipato API REST service.
        /// </summary>
        /// <param name="userNameEmail">User name (typically the email address you use on my.zipato.com)</param>
        /// <param name="password">Password</param>
        public async Task LoginAsync(string userNameEmail, string password)
        {
            // First call user/init which returns us a nonce
            _httpClient = new RestClient();
            _httpClient.BaseUrl = ApiUrl;
            var jsonSerializerSettings = new JsonSerializerSettings { ContractResolver = new CamelCasePropertyNamesContractResolver() };
            _httpClient.JsonSerializerSettings = jsonSerializerSettings;

            var initRequest = new RestRequest("user/init", HttpMethod.Get);
            
            var initResult = await _httpClient.ExecuteWithPolicyAsync<InitResponse>(this, initRequest, byPassCheckInitialized:true);
            if (!initResult.Success)                
                throw new CannotInitializeSessionException();

            // Save the JSessionId, because we pass this as Cookie value to all future requests
            Jessionid = initResult.JSessionId;
            // SHA1-hash the password with the nonce (protects against cross-site forgery)
            string token = Utils.GetToken(password, initResult.Nonce);

            // Sign in with user name and token
            var loginRequest = new RestRequest("user/login", HttpMethod.Get);
            
            loginRequest.AddQueryString("username", userNameEmail);
            loginRequest.AddQueryString("token", token);
            var loginResult = await _httpClient.ExecuteWithPolicyAsync<UserSession>(this, loginRequest, byPassCheckInitialized: true);

            if (!loginResult.Success)
                throw new AuthenticationFailureException(loginResult.Error);

            if (_requireZipaboxOnline)
            {
                _initialized = await CheckConnection();
            }
            else
                _initialized = true;
        }
开发者ID:nicolascastel,项目名称:Zipato.NET,代码行数:41,代码来源:ZipatoClient.cs


注:本文中的RestClient.ExecuteWithPolicyAsync方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。