• <sub id="xcyjv"></sub><nav id="xcyjv"><code id="xcyjv"><meter id="xcyjv"></meter></code></nav>
      <nav id="xcyjv"></nav>
    1. <form id="xcyjv"><th id="xcyjv"></th></form><nav id="xcyjv"><mark id="xcyjv"></mark></nav>

        .net core webapi通過中間件獲取請求和響應內容的方法

         更新時間:2019年09月17日 11:48:01   作者:微流   我要評論
        這篇文章主要介紹了.net core webapi通過中間件獲取請求和響應內容的方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

        本文主要根據中間件來實現對.net core webapi中產生的請求和響應數據進行獲取并存入日志文件中;

        這里不詳細介紹日志文件的使用。你可以自己接入NLog,log4net,Exceptionless等

        創建接口記錄的中間件

        using Microliu.Core.Loggers;
        using Microsoft.AspNetCore.Builder;
        using Microsoft.AspNetCore.Http;
        using Microsoft.AspNetCore.Http.Internal;
        using Newtonsoft.Json;
        using System;
        using System.Collections.Generic;
        using System.Diagnostics;
        using System.IO;
        using System.Linq;
        using System.Text;
        using System.Threading.Tasks;
        namespace Ptibro.Partner.API.Extensions
        {
          public class RequestResponseLoggingMiddleware
          {
            private readonly RequestDelegate _next;
            private readonly ILogger _logger;
            private SortedDictionary<string, object> _data;
            private Stopwatch _stopwatch;
            public RequestResponseLoggingMiddleware(RequestDelegate next, ILogger logger)
            {
              _next = next;
              _logger = logger;
              _stopwatch = new Stopwatch();
            }
            public async Task Invoke(HttpContext context)
            {
              _stopwatch.Restart();
              _data = new SortedDictionary<string, object>();
              HttpRequest request = context.Request;
              _data.Add("request.url", request.Path.ToString());
              _data.Add("request.headers", request.Headers.ToDictionary(x => x.Key, v => string.Join(";", v.Value.ToList())));
              _data.Add("request.method", request.Method);
              _data.Add("request.executeStartTime", DateTimeOffset.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"));
              // 獲取請求body內容
              if (request.Method.ToLower().Equals("post"))
              {
                // 啟用倒帶功能,就可以讓 Request.Body 可以再次讀取
                request.EnableRewind();
                Stream stream = request.Body;
                byte[] buffer = new byte[request.ContentLength.Value];
                stream.Read(buffer, 0, buffer.Length);
                _data.Add("request.body", Encoding.UTF8.GetString(buffer));
                request.Body.Position = 0;
              }
              else if (request.Method.ToLower().Equals("get"))
              {
                _data.Add("request.body", request.QueryString.Value);
              }
              // 獲取Response.Body內容
              var originalBodyStream = context.Response.Body;
              using (var responseBody = new MemoryStream())
              {
                context.Response.Body = responseBody;
                await _next(context);
                _data.Add("response.body", await GetResponse(context.Response));
                _data.Add("response.executeEndTime", DateTimeOffset.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"));
                await responseBody.CopyToAsync(originalBodyStream);
              }
              // 響應完成記錄時間和存入日志
              context.Response.OnCompleted(() =>
              {
                _stopwatch.Stop();
                _data.Add("elaspedTime", _stopwatch.ElapsedMilliseconds + "ms");
                var json = JsonConvert.SerializeObject(_data);
                _logger.Debug(json, "api", request.Method.ToUpper());
                return Task.CompletedTask;
              });
            }
            /// <summary>
            /// 獲取響應內容
            /// </summary>
            /// <param name="response"></param>
            /// <returns></returns>
            public async Task<string> GetResponse(HttpResponse response)
            {
              response.Body.Seek(0, SeekOrigin.Begin);
              var text = await new StreamReader(response.Body).ReadToEndAsync();
              response.Body.Seek(0, SeekOrigin.Begin);
              return text;
            }
          }
          /// <summary>
          /// 擴展中間件
          /// </summary>
          public static class RequestResponseLoggingMiddlewareExtensions
          {
            public static IApplicationBuilder UseRequestResponseLogging(this IApplicationBuilder app)
            {
              return app.UseMiddleware<RequestResponseLoggingMiddleware>();
            }
          }
        }

        在startup.cs中Configure方法中使用中間件

          public void Configure(IApplicationBuilder app, IHostingEnvironment env)
            {
              if (env.IsDevelopment())
              {
                app.UseDeveloperExceptionPage();
              }
              app.UseErrorHandling();// 全局異常盡量放上面
              ...
              app.UseRequestResponseLogging();
              ...
              app.UseExceptionless(Configuration);
              app.UseMvc();
            }

        現在請求一次看一下記錄的效果:我的日志存在exceptionless上,如下圖

         解析json,記錄的數據如下:

        總結

        以上所述是小編給大家介紹的.net core webapi通過中間件獲取請求和響應內容的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
        如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

        相關文章

        最新評論

        01彩票网app
      1. <sub id="xcyjv"></sub><nav id="xcyjv"><code id="xcyjv"><meter id="xcyjv"></meter></code></nav>
          <nav id="xcyjv"></nav>
        1. <form id="xcyjv"><th id="xcyjv"></th></form><nav id="xcyjv"><mark id="xcyjv"></mark></nav>
            陇南 | 丽江 | 伊犁 | 丽江 | 曲靖 | 汕尾 | 乌兰察布 | 日土 | 安顺 | 乌海 | 德州 | 镇江 | 乐清 | 荆门 | 雄安新区 | 宜春 | 宜宾 | 上饶 | 晋江 | 陕西西安 | 桐乡 | 海西 | 三沙 | 自贡 | 阳春 | 牡丹江 | 吐鲁番 | 益阳 | 淮南 | 庆阳 | 鄢陵 | 惠州 | 巢湖 | 铜川 | 咸阳 | 丽江 | 安阳 | 天门 | 石河子 | 锡林郭勒 | 十堰 | 榆林 | 日土 | 舟山 | 荣成 | 黔南 | 白城 | 鹰潭 | 新沂 | 明港 | 韶关 | 铜仁 | 南平 | 白山 | 常州 | 琼海 | 汕尾 | 保定 | 佳木斯 | 临沧 | 任丘 | 咸宁 | 大庆 | 塔城 | 临猗 | 公主岭 | 莱芜 | 达州 | 新乡 | 陇南 | 大庆 | 莱芜 | 白城 | 张掖 | 崇左 | 赵县 | 广饶 | 盘锦 | 吉林长春 | 濮阳 | 通辽 | 莱州 | 海门 | 燕郊 | 乐清 | 商洛 | 林芝 | 崇左 | 淮安 | 威海 | 衢州 | 台中 | 桂林 | 肇庆 | 三沙 | 鄂尔多斯 | 吉林长春 | 张家口 | 长兴 | 咸阳 | 大庆 | 岳阳 | 锡林郭勒 | 聊城 | 金昌 | 江门 | 锡林郭勒 | 石狮 | 信阳 | 三亚 | 齐齐哈尔 | 桂林 | 六盘水 | 喀什 | 徐州 | 任丘 | 海丰 | 定州 | 乐平 | 洛阳 | 乌兰察布 | 徐州 | 霍邱 | 鹤岗 | 三河 | 梧州 | 泰兴 | 清徐 | 万宁 | 通化 | 桂林 | 四川成都 | 临夏 | 长葛 | 龙口 | 菏泽 | 营口 | 果洛 | 滁州 | 日照 | 张家口 | 保定 | 襄阳 | 齐齐哈尔 | 枣阳 | 张北 | 吕梁 | 福建福州 | 澄迈 | 秦皇岛 | 厦门 | 新余 | 聊城 | 长治 | 曲靖 | 白银 | 池州 | 张北 | 苍南 | 厦门 | 邢台 | 景德镇 | 双鸭山 | 江苏苏州 | 衢州 | 吉林长春 | 偃师 | 石嘴山 | 商丘 | 晋江 | 内蒙古呼和浩特 | 连云港 | 东台 | 四川成都 | 惠州 | 锡林郭勒 | 新余 | 芜湖 | 济南 | 资阳 | 湛江 | 莱芜 | 娄底 | 桂林 | 澄迈 | 西双版纳 | 内蒙古呼和浩特 | 日照 | 娄底 | 象山 | 七台河 | 镇江 | 江门 | 偃师 | 朝阳 | 潜江 | 大同 | 桐城 | 秦皇岛 | 保定 | 辽源 | 晋城 | 定西 | 文山 | 池州 | 屯昌 | 陇南 | 陵水 | 安吉 | 库尔勒 | 瓦房店 | 伊犁 | 三沙 | 台湾台湾 | 武安 | 宁夏银川 | 七台河 | 神木 | 新乡 | 仁怀 | 长治 | 云南昆明 | 汝州 | 七台河 | 定州 | 汕尾 | 惠东 | 蚌埠 | 武安 | 鄂尔多斯 | 安康 | 安岳 | 鹤壁 | 舟山 | 朝阳 | 阿克苏 | 汕尾 | 大连 | 果洛 | 甘肃兰州 | 舟山 | 平凉 | 厦门 | 三明 | 辽阳 | 甘肃兰州 | 阿里 | 红河 | 仁寿 | 雅安 | 茂名 | 济南 | 兴化 | 安顺 | 石狮 | 德阳 | 贺州 | 克孜勒苏 | 青州 | 阿坝 | 本溪 | 大庆 | 七台河 | 鄂尔多斯 | 甘肃兰州 | 常州 | 汕头 | 岳阳 | 萍乡 | 大同 | 芜湖 | 五家渠 | 贵州贵阳 | 云南昆明 | 保山 | 平凉 | 日喀则 | 醴陵 | 遵义 | 台州 | 阳江 | 阜阳 | 鄂尔多斯 | 黑河 | 深圳 | 咸宁 | 青州 | 南安 | 怀化 | 湘西 | 黔东南 | 鄂州 | 嘉兴 | 涿州 | 株洲 | 呼伦贝尔 | 亳州 | 正定 | 运城 | 上饶 | 柳州 | 桐乡 | 延边 | 那曲 | 日土 | 哈密 | 新沂 | 吉林长春 | 三明 | 本溪 | 阳春 | 随州 | 五指山 | 常州 | 姜堰 | 白山 | 博尔塔拉 | 福建福州 | 塔城 | 六盘水 | 大兴安岭 | 黄石 | 防城港 | 铜仁 | 临汾 | 漳州 | 莱州 | 黑河 | 南京 | 茂名 | 湘潭 | 海南 | 天门 | 酒泉 | 南充 | 安吉 | 垦利 | 滕州 | 宜春 | 洛阳 | 阳春 | 海东 | 秦皇岛 | 江门 | 芜湖 | 岳阳 | 乌兰察布 | 玉溪 | 和县 | 淮安 | 安庆 | 南阳 | 玉溪 | 诸暨 | 九江 | 包头 | 如东 | 崇左 | 大理 | 聊城 | 昌吉 | 赣州 | 漯河 | 湖北武汉 | 大庆 | 鄢陵 | 喀什 | 济源 | 达州 | 和县 | 三亚 | 白沙 | 宜宾 | 章丘 | 东阳 | 定州 | 滨州 | 偃师 | 河源 | 宁国 | 海南 | 马鞍山 | 安康 | 云南昆明 | 梅州 | 万宁 | 开封 | 芜湖 | 张掖 | 吴忠 | 陕西西安 | 黄南 | 东方 | 神木 | 乌海 | 铜川 | 阿坝 | 姜堰 | 盘锦 | 达州 | 盘锦 | 宜都 | 台中 | 咸阳 | 仁怀 | 安康 | 新乡 | 禹州 | 芜湖 | 吉安 | 渭南 | 焦作 | 台中 | 铜陵 | 辽阳 | 临海 | 鞍山 | 慈溪 | 武安 | 滕州 | 乐平 | 巴中 | 乌兰察布 | 海北 | 荆门 | 三沙 | 铜仁 | 锡林郭勒 | 玉溪 | 新疆乌鲁木齐 | 海西 | 宁德 | 定安 | 延边 | 铜仁 | 金昌 | 昭通 | 松原 | 保山 | 滁州 | 沭阳 | 驻马店 | 启东 | 毕节 | 徐州 | 西藏拉萨 | 阜阳 | 苍南 | 资阳 | 余姚 | 牡丹江 | 武威 | 海宁 | 灵宝 | 新疆乌鲁木齐 | 梅州 | 桓台 | 台南 | 丽水 | 信阳 | 伊犁 | 衡水 | 燕郊 | 图木舒克 | 三沙 | 珠海 | 五家渠 | 馆陶 | 莒县 | 任丘 | 伊犁 | 延安 | 安吉 | 清远 | 商丘 | 河南郑州 | 和县 | 信阳 | 巴音郭楞 | 邳州 | 香港香港 | 兴化 | 新余 | 江苏苏州 | 益阳 | 资阳 | 桐乡 | 灵宝 | 南安 | 临沂 | 衡水 | 三明 | 日喀则 | 攀枝花 | 运城 | 克孜勒苏 | 曹县 | 白沙 | 琼中 | 荣成 | 楚雄 | 昌吉 | 自贡 | 台南 | 绥化 | 海南海口 | 宁波 | 池州 | 北海 | 怀化 | 三明 | 中卫 | 营口 | 大丰 | 六盘水 | 东营 | 锡林郭勒 | 广汉 | 巴彦淖尔市 | 邹城 | 芜湖 | 宁夏银川 | 沭阳 | 安吉 | 鹤壁 | 沭阳 | 枣阳 | 包头 | 湘潭 | 金华 | 淮安 | 乳山 | 中卫 | 河北石家庄 | 宁国 | 广元 | 清徐 | 丹东 | 东莞 | 襄阳 | 榆林 | 防城港 | 正定 | 湖北武汉 | 日喀则 | 临沧 | 揭阳 | 普洱 | 燕郊 | 淮安 | 东莞 | 大兴安岭 | 平潭 | 荣成 | 抚顺 | 锦州 | 巴彦淖尔市 | 肇庆 | 龙岩 | 包头 | 荣成 | 晋城 | 自贡 | 泗洪 | 淮南 | 四平 | 醴陵 | 莒县 | 贵港 | 玉溪 | 黔西南 | 张家口 | 宝鸡 | 萍乡 | 诸城 | 库尔勒 | 大同 | 溧阳 | 宁德 | 湖北武汉 | 安庆 | 库尔勒 | 大同 | 大同 | 广元 | 塔城 | 那曲 | 秦皇岛 | 延安 | 燕郊 | 灌南 | 锦州 | 包头 | 通辽 | 丹东 | 金昌 | 齐齐哈尔 | 云南昆明 | 三明 | 阿拉尔 | 雅安 | 保山 | 巢湖 | 肇庆 | 阜阳 | 海拉尔 | 凉山 | 湖北武汉 | 莒县 | 新沂 | 玉溪 | 如东 | 任丘 | 杞县 | 乳山 | 泰州 | 巴音郭楞 | 绥化 | 天长 | 延边 | 南京 | 天水 | 昌吉 | 林芝 | 巴音郭楞 | 临海 | 鞍山 | 泰安 | 象山 | 呼伦贝尔 | 内蒙古呼和浩特 | 丽水 | 赣州 | 湛江 | 文山 | 怀化 | 厦门 | 东方 | 马鞍山 | 德阳 | 黄南 | 吴忠 | 衢州 | 陵水 | 宣城 | 嘉善 | 开封 | 鹤岗 | 濮阳 | 广汉 | 咸宁 | 三明 | 博罗 | 安岳 | 六盘水 | 安徽合肥 | 三河 | 寿光 | 陕西西安 | 临海 | 招远 | 黑河 | 陵水 | 内蒙古呼和浩特 | 德阳 | 西藏拉萨 | 公主岭 | 桂林 | 榆林 | 安阳 | 林芝 | 孝感 | 保亭 | 阳春 | 中山 | 丽江 | 辽阳 | 湖北武汉 | 株洲 | 临沧 | 垦利 | 梅州 | 伊犁 | 广元 | 西藏拉萨 | 铜仁 | 泰州 | 德阳 | 张掖 | 广饶 | 贵州贵阳 | 乌兰察布 | 那曲 | 河池 | 台中 | 平顶山 | 博罗 | 保定 | 新疆乌鲁木齐 | 烟台 | 九江 | 济南 | 玉树 | 石狮 | 丹东 | 吉林长春 | 湘潭 | 安阳 | 任丘 | 廊坊 | 吉林 | 西藏拉萨 | 宜春 | 乳山 | 陇南 | 益阳 | 伊犁 | 大理 | 邯郸 | 屯昌 | 庆阳 | 毕节 | 珠海 | 济南 | 新乡 | 丹东 | 桐乡 | 菏泽 | 柳州 | 昌都 | 博罗 | 淮南 | 金华 | 溧阳 | 高密 | 大丰 | 黔东南 | 荆门 | 三河 | 仙桃 | 龙口 | 莒县 | 天水 | 保山 | 安顺 | 南京 | 常州 | 凉山 | 邹城 | 承德 | 澳门澳门 | 大连 | 浙江杭州 | 绵阳 | 普洱 | 忻州 | 塔城 | 咸阳 | 通辽 | 南平 | 白城 | 衡阳 | 福建福州 | 赤峰 | 三门峡 | 锡林郭勒 | 新沂 | 商丘 | 汉中 | 黑龙江哈尔滨 | 溧阳 | 蓬莱 | 澳门澳门 | 张家口 | 菏泽 | 菏泽 | 沧州 | 昌吉 | 佛山 | 舟山 | 海南 | 信阳 | 安岳 | 佛山 | 乌海 | 姜堰 | 德清 | 松原 | 平顶山 | 德宏 | 诸城 | 厦门 | 赤峰 | 崇左 | 巴音郭楞 | 乐清 | 台湾台湾 | 雅安 | 宜春 | 曲靖 | 锦州 | 商丘 | 五指山 | 吴忠 | 山南 | 荆州 | 邳州 | 儋州 | 桓台 | 赵县 | 海东 | 张北 | 克孜勒苏 | 洛阳 | 深圳 | 昌吉 | 东莞 | 台山 | 阿拉善盟 | 南充 | 巢湖 | 内江 | 招远 | 白山 | 曲靖 | 山西太原 | 台湾台湾 | 广汉 | 天长 | 昌吉 | 萍乡 | 包头 | 曲靖 | 嘉善 | 三河 | 南京 | 库尔勒 | 邵阳 | 改则 | 廊坊 | 桐乡 | 象山 | 金华 | 日照 | 日喀则 | 任丘 | 承德 | 丹阳 | 张家界 | 泗洪 | 毕节 | 仙桃 | 那曲 | 正定 | 哈密 | 泗洪 | 连云港 | 克拉玛依 | 宣城 | 清徐 | 晋江 | 惠东 | 贵州贵阳 | 乐山 | 甘孜 | 秦皇岛 | 龙岩 | 招远 | 海东 | 吉林长春 | 安阳 | 济源 | 顺德 | 鄢陵 | 钦州 | 台北 | 新乡 | 济南 | 黄山 | 德阳 | 济宁 | 济宁 | 蓬莱 | 屯昌 | 厦门 | 海西 | 哈密 | 湘潭 | 临汾 | 德州 | 北海 | 淮北 | 郴州 | 宜昌 | 德阳 | 湖州 | 定安 | 陵水 | 临沧 | 永州 | 周口 | 神农架 | 汝州 | 垦利 | 铜仁 | 甘肃兰州 | 三亚 | 黔西南 | 吉林 | 金坛 | 沛县 | 焦作 | 嘉兴 | 儋州 | 新沂 | 启东 | 阳春 | 铜仁 | 石河子 | 黑河 | 三明 | 潜江 | 灌南 | 巴彦淖尔市 | 鸡西 | 临夏 | 咸宁 | 辽阳 | 迪庆 | 铜陵 | 陕西西安 | 喀什 | 哈密 | 吉林 | 玉树 | 肥城 | 陵水 | 宁夏银川 | 鹰潭 | 沧州 | 贵州贵阳 | 湖州 | 龙岩 | 北海 | 镇江 | 明港 | 乐山 | 永新 | 滨州 | 金坛 | 威海 | 北海 | 黄山 | 玉林 | 日喀则 | 香港香港 | 庄河 | 新余 | 姜堰 | 鄂尔多斯 | 寿光 | 徐州 | 白银 | 宁德 | 三亚 | 南通 | 张家口 | 湖北武汉 | 长葛 | 乐平 | 抚顺 | 大连 | 台湾台湾 | 公主岭 | 海东 | 延安 | 大庆 | 益阳 | 新沂 | 枣庄 | 德阳 | 白山 | 雄安新区 | 山西太原 | 新乡 | 达州 | 汕尾 | 瑞安 | 枣庄 | 宜昌 | 平顶山 | 台南 | 永新 | 赵县 | 项城 | 茂名 | 海西 | 阿克苏 | 象山 | 庆阳 | 锦州 | 余姚 | 安康 | 吉林长春 | 潮州 | 鹤岗 | 焦作 | 济南 | 晋城 | 和田 | 灌云 | 扬州 | 衢州 | 单县 | 凉山 | 大理 | 东方 | 沧州 | 日照 | 孝感 | 巴中 | 怀化 | 商丘 | 揭阳 | 山西太原 | 滁州 | 芜湖 | 滁州 | 鸡西 | 长葛 | 阿勒泰 | 石嘴山 | 安康 | 三亚 | 济南 | 丹阳 | 临沧 | 新余 | 周口 | 榆林 | 贵港 | 凉山 | 安康 | 朔州 | 阿拉尔 | 延边 | 巴彦淖尔市 | 株洲 | 湛江 | 东方 | 昭通 | 萍乡 | 渭南 | 毕节 | 青州 | 鹰潭 | 巴彦淖尔市 | 湖北武汉 | 武威 | 果洛 | 晋江 | 昌吉 | 北海 | 海南海口 | 雅安 | 宜宾 | 单县 | 仁怀 | 三明 | 如皋 | 喀什 | 七台河 | 廊坊 | 丽江 | 白山 | 儋州 | 湖南长沙 | 乐山 | 杞县 | 吉林长春 |