RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1011153
Accepted
Артур Франк
Артур Франк
Asked:2020-08-07 23:16:32 +0000 UTC2020-08-07 23:16:32 +0000 UTC 2020-08-07 23:16:32 +0000 UTC

获取 POST 请求。完全控制收到的回复

  • 772

再会!

我有这个代码发送一个 POST 请求并从服务器接收响应:

private readonly WebClient wc = new WebClient();

        public async Task<string> POST(string URI, string body, string AccessToken = null)
        {
            try
            {
                wc.Headers[HttpRequestHeader.ContentType] = "application/x-www-form-urlencoded";
                if (AccessToken != null)
                {
                    wc.Headers.Add("Authorization", AccessToken);
                }
                string result = await wc.UploadStringTaskAsync(URI, body);
                return result;
            }
            catch (WebException we)
            {
                log.WriteLog("RaidBoss", we.ToString());
                return null;
            }

        }

对于每个不同于 200 的响应,都会触发异常。您可以从中提取响应代码,但不能提取响应中发送给我的 JSON 代码。

如何处理所有响应(任何代码都不会引发异常)?您可能需要使用不同的方式来发送 POST。

GET 请求也存在同样的问题:

public async Task<string> GET(string URI, string Params = "", string AccessToken = null)
        {
            try
            {
                HttpClient hc = new HttpClient();
                if (AccessToken != null)
                {
                    hc.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue(AccessToken);
                }
                Task<Stream> result = hc.GetStreamAsync(URI + "?" + Params);

                Stream vs = await result;
                StreamReader am = new StreamReader(vs);

                string res = await am.ReadToEndAsync();


                return res;
            }
            catch (Exception ex)
            {
                return null;
            }
        }

在这种情况下提示在哪里挖掘。我会非常感谢!

在此处输入图像描述

c#
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. A K
    2020-08-07T23:37:25Z2020-08-07T23:37:25Z

    对于 200 以外的响应,可能没有任何 json。你需要往职责分离的方向去挖掘:访问站点的单独操作,解析json的单独操作。传输层分开,消息解码分开。

    在基类中——请求的实际执行(抛出一个字符串——接收到一个字符串):

    public class WebServiceBase
    {
        public string MakeRequest(string url, string body)
        {
            try
            {
                var client = new WebClient();
                // ...
            }
            catch (WebException e)
            {
                // ...
            }
        }
    }
    

    在api中已经可以操作TRequest和TResponse:

    public class WebsiteService : WebServiceBase
    {
        public TResponse Call<TRequest, TResponse>(TRequest request)
        {
            this.Call<TRequest>(request);
    
            try
            {
                var answer = JsonConvert.DeserializeObject<TResponse>(this.Response);
                return answer;
            }
            catch (Exception ex)
            {
                // ...
            }
        }
    
        private string Call<TRequest>(TRequest request)
        {
            this.Request = JsonConvert.SerializeObject(request);
            this.Response = string.Empty;
    
            try
            {
                this.Response = this.MakeRequest(this.RequestUrl, this.Secret, this.Request);
                return this.Response;
            }
            catch (WebException ex)
            {
                // ...
            }
        }
    
        private string Request { get; set; }
    
        private string Response { get; set; }
    }
    
    • 1
  2. Best Answer
    Артур Франк
    2020-08-08T03:05:57Z2020-08-08T03:05:57Z

    感谢@vitidev 帮助我解决这个问题。

    结果是这样的:

    邮政:

    
    public async Task<string> POST(string URI, object body, string AccessToken = null)
            {
                try
                {
                    using (HttpClient httpClient = new HttpClient())
                    {
                        if (AccessToken != null)
                        {
                            httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue(AccessToken);                    
                        }
    
                        HttpContent httpContent = new StringContent(JsonConvert.SerializeObject(body), Encoding.UTF8);
                        httpContent.Headers.ContentType = new MediaTypeHeaderValue("application/json");
    
                        var response = await httpClient.PostAsync(URI, httpContent);
                        return await response.Content.ReadAsStringAsync();
                    }
                }
                catch(Exception ex)
                {
                    log.WriteLog("Action: POST", ex.Message, 101);
                    return null;
                }
            }
    
    

    得到:

            public async Task<string> GET(string URI, string Params = "", string AccessToken = null)
            {
                try
                {
                    using (HttpClient httpClient = new HttpClient())
                    {
                        if (AccessToken != null)
                        {
                            httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue(AccessToken);
                        }
    
                        var response = await httpClient.GetAsync(URI + "?" + Params);
                        return await response.Content.ReadAsStringAsync();
                    }
                }
                catch (Exception ex)
                {
                    log.WriteLog("Action: GET", ex.Message, 102);
                    return null;
                }
            }
    

    POST 和 GET 响应代码可以在函数本身内部获取:

                  if (response.StatusCode == HttpStatusCode.OK){}           // Код 200
                  if (response.StatusCode == HttpStatusCode.NotFound){}     // Код 404
                  if (response.StatusCode == HttpStatusCode.Unauthorized){} // Код 401
                  if (response.StatusCode == HttpStatusCode.NoContent){}    // Код 204
                  if (response.StatusCode == HttpStatusCode.Conflict){}     // Код 409
    
    

    还有很多很多不同的代码HttpStatusCode

    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    根据浏览器窗口的大小调整背景图案的大小

    • 2 个回答
  • Marko Smith

    理解for循环的执行逻辑

    • 1 个回答
  • Marko Smith

    复制动态数组时出错(C++)

    • 1 个回答
  • Marko Smith

    Or and If,elif,else 构造[重复]

    • 1 个回答
  • Marko Smith

    如何构建支持 x64 的 APK

    • 1 个回答
  • Marko Smith

    如何使按钮的输入宽度?

    • 2 个回答
  • Marko Smith

    如何显示对象变量的名称?

    • 3 个回答
  • Marko Smith

    如何循环一个函数?

    • 1 个回答
  • Marko Smith

    LOWORD 宏有什么作用?

    • 2 个回答
  • Marko Smith

    从字符串的开头删除直到并包括一个字符

    • 2 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5