net core http请求响应中间件 及全局异常中间件小计
时间:2020-03-24
本文章向大家介绍net core http请求响应中间件 及全局异常中间件小计,主要包括net core http请求响应中间件 及全局异常中间件小计使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
using Microsoft.AspNetCore.Http; using Newtonsoft.Json; using NLog; using System; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.Linq; using System.Text; using System.Threading.Tasks; namespace WebApplication8 { public class RequestResponseLoggingMiddleware { private readonly RequestDelegate _next; private readonly Logger _logger; public RequestResponseLoggingMiddleware(RequestDelegate next) { _next = next; _logger = LogManager.GetCurrentClassLogger(); } public async Task Invoke(HttpContext context) { string userName = "", requestInfo = "", responseInfo = ""; var originalBodyStream = context.Response.Body; var stopwach = Stopwatch.StartNew(); try { requestInfo = await FormatRequest(context.Request); //context.Items["requestInfo"] = requestInfo; using (var responseBody = new MemoryStream()) { context.Response.Body = responseBody; await _next(context); stopwach.Stop(); responseInfo = await FormatResponse(context.Response); //context.Items["responseInfo"] = responseInfo; await responseBody.CopyToAsync(originalBodyStream); } userName = Convert.ToString(context.Items["userName"]); var logMsg = $@"{userName} 请求信息: {requestInfo}{Environment.NewLine}响应信息: {responseInfo}{Environment.NewLine}耗时: {stopwach.ElapsedMilliseconds}ms"; _logger.Log(LogLevel.Info, logMsg); } catch (Exception ex) { stopwach.Stop(); if (ex != null) { var logMsg = $@"{userName} 请求信息: {requestInfo}{Environment.NewLine}异常: {ex.ToString()}{Environment.NewLine}耗时: {stopwach.ElapsedMilliseconds}ms"; _logger.Log(LogLevel.Error, logMsg); _logger.Log(LogLevel.Error, ex.ToString()); var errResult = new ReturnValue(ResultCode.系统发生错误, ex.Message); var bytes = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(errResult)); await originalBodyStream.WriteAsync(bytes, 0, bytes.Length); } } } private async Task<string> FormatRequest(HttpRequest request) { HttpRequestRewindExtensions.EnableBuffering(request); var body = request.Body; var buffer = new byte[Convert.ToInt32(request.ContentLength)]; await request.Body.ReadAsync(buffer, 0, buffer.Length); var bodyAsText = Encoding.UTF8.GetString(buffer); body.Seek(0, SeekOrigin.Begin); request.Body = body; return $" {request.Method} {request.Scheme}://{request.Host}{request.Path} {request.QueryString} {bodyAsText}"; } private async Task<string> FormatResponse(HttpResponse response) { response.Body.Seek(0, SeekOrigin.Begin); var text = await new StreamReader(response.Body).ReadToEndAsync(); response.Body.Seek(0, SeekOrigin.Begin); return $"{response.StatusCode}: {text}"; } } }
放在startup的Configure方法所有中间件最上面
app.UseMiddleware<RequestResponseLoggingMiddleware>();
原文地址:https://www.cnblogs.com/xtxtx/p/12561043.html
- python接口自动化14-multipart/form-data上传图片
- 【干货】RL-GAN For NLP: 强化学习在生成对抗网络文本生成中扮演的角色
- python接口自动化15-multipart/form-data表单提交
- appium+python自动化32-android_uiautomator定位进阶版
- appium+python自动化33-解锁九宫格(TouchAction)
- 用qemu中最少的代码实现一个kvm模拟器
- 关关的刷题日记07——Leetcode 26. Remove Duplicates from Sorted Array 方法1
- openstack如何扩展API之一:新添加API
- 值得收臧 | 从零开始搭建带GPU加速的深度学习环境(操作系统、驱动和各种机器学习库)
- python接口自动化16-multipart/form-data上传多个附件
- python接口自动化17-响应时间与超时(timeout)
- python+requests+excel接口自动化数据驱动
- python+selenium+requests爬取我的博客粉丝的名称
- python接口自动化21-规范的API接口文档示例
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Discourse CentOS 8 全新安装手册
- H2 数据库插入时间的方法
- Spring 配置的 H2 控制台 frameOptions 导致无法访问
- Spring Boot 和 Hibernate 的 H2 数据库配置来进行启动测试
- Java时间处理-LocalDateTime简介
- iOS音视频接入 - TRTC iOS端真机日志导出
- jQuery根据填写的input的数值导出excel表格
- 小程序根据返回值英文渲染出对应的中文
- 小程序返回的时间戳转化成时间
- 小程序使用 组件库 vant-weapp详细教程
- 小程序数据渲染根据返回值计算百分比并且显示
- JS获取当前系统时间戳的方法
- TensorFlow 2建立神经网络分类模型——以iris数据为例
- 突击并发编程JUC系列-阻塞队列 BlockingQueue
- Matlab建立SVM,KNN和朴素贝叶斯模型分类绘制ROC曲线