Lind.DDD.Utils.HttpHelper里静态对象引出的Http超时问题

回到目录

Lind.DDD.Utils.HttpHelper组件主要实现了对HTTP的各种操作,如Get,Post,Put和Delete,它属于最纯粹的操作,大叔把它封装的目的主要为了实现与API安全授权的统一,你不可能为每个请求都写一个“逻辑完全一样的加密规则”,这是违背DRY原则的,我们应该通过面向对象的各位原则,将这种可变的部分封装!

公开的统一方法

真正的对象转键/值对

支持对复杂类型,集合类型转为Dictionary的键值对,它并不是网上说的,只把一层属性进行拼接,而是大叔利用递归写了一个算法,琢层查找对象。

复制代码
      /// <summary>
        /// 将对象转为键值对象(完全支持最复杂的类型)
        /// 作者:仓储大叔
        /// </summary>
        /// <param name="obj"></param>
        /// <returns></returns>
        public static IDictionary<string, string> ToDictionary(this object obj)
        {
            try
            {
                var dic = new Dictionary<string, string>();
                var prefix = new Dictionary<string, string>();
                foreach (var p in obj.GetType().GetProperties(BindingFlags.Public | BindingFlags.Instance))
                {
                    ReGenerate(obj, p, prefix, dic, null);
                    prefix.Clear();
                }
                return dic;
            }
            catch (Exception)
            {

                throw;
            }

        }
复制代码

其中ReGenerate核心方法被封装到了Lind.DDD.Utils.HttpHelper组件里

静态对象引起的超时

对于Http方法来说,我们可以定义它的handler,添加一些压缩,代理,身份验证等信息,但在组件设计时一定要注意,当你定义了handler之后,如果又显示的设计了超时时间,千万不要将handler做成全局静态属性,因为这样会让你的第一次请求后的其它请求都超时,因为你的超时时间依赖你全局的handler,正确的做法,应该在每个方法里(get,post,put,delete)定义自已的handler,类似这样的代码是正确的。

复制代码
        public static HttpResponseMessage Get(string requestUri, NameValueCollection nv = null, int timeOut = 10)
        {
            var handler = new HttpClientHandler() { AutomaticDecompression = System.Net.DecompressionMethods.GZip };
            using (var http = new HttpClient(handler))
            {    //超时
                http.Timeout = new TimeSpan(0, 0, timeOut);
                HttpResponseMessage response;
                try
                {
                    response = http.GetAsync(GeneratorUri(requestUri, ApiValidateHelper.GenerateCipherText(nv))).Result;
                }
                catch (Exception ex)
                {
                    response = new HttpResponseMessage(System.Net.HttpStatusCode.RequestTimeout) { Content = new StringContent("请求超时") };
                    Logger.LoggerFactory.Instance.Logger_Error(ex);
                }

                return response;
            }
        }
复制代码

对于一种知识,一个概念的理解程度,有时决定了组件设计的正确性与安全性!

让我们一起对技术做更深入,更直接的研究吧!

回到目录

posted @   张占岭  阅读(1048)  评论(0编辑  收藏  举报
编辑推荐:
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
阅读排行:
· 【.NET】调用本地 Deepseek 模型
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
历史上的今天:
2011-09-02 点某个链接进网站,会发这个链接的会员加积分,实现方法(有时间限制)
点击右上角即可分享
微信分享提示