C# .Net Framework webapi 全局日志

1.创建一个类名字叫做CustomActionFilter.cs

/// <summary>/// /// </summary>public class CustomActionFilter : System.Web.Http.Filters.ActionFilterAttribute{/// <summary>/// /// </summary>/// <param name="actionExecutedContext"></param>/// <param name="cancellationToken"></param>/// <returns></returns>public override Task OnActionExecutedAsync(HttpActionExecutedContext actionExecutedContext, CancellationToken cancellationToken){HttpRequest request = HttpContext.Current.Request;string token = request.Headers["token"];string strUserName = null;try{strUserName = AesUtil.Decrypt(token, UserInformation.strGuid);}catch (Exception ex){throw new Exception($"token:【{token}】无效");}if (string.IsNullOrWhiteSpace(strUserName))throw new Exception($"token:【{token}】无效");var obj=  DependencyInjection.Container.ICustomTableOperations.userInformation(strUserName);if (obj.IntCode == ReturnState.失败)throw new Exception(obj.strErr);// 获取request提交的参数var Paramaters = GetRequestValues(actionExecutedContext);// 获取response响应的结果var ExecuteResult = GetResponseValues(actionExecutedContext);dynamic data = JsonConvert.DeserializeObject(ExecuteResult);// 获取访问的ipvar UserHostAddress = request.UserHostAddress;//请求地址var path = request.AppRelativeCurrentExecutionFilePath;return base.OnActionExecutedAsync(actionExecutedContext, cancellationToken);}public string GetRequestValues(HttpActionExecutedContext actionExecutedContext){Stream stream = actionExecutedContext.Request.Content.ReadAsStreamAsync().Result;stream.Position = 0;Encoding encoding = Encoding.UTF8;/*这个StreamReader不能关闭,也不能dispose因为你关掉后,后面的管道  或拦截器就没办法读取了*/var reader = new StreamReader(stream, encoding);string result = reader.ReadToEnd();/*这里也要注意:   stream.Position = 0;当你读取完之后必须把stream的位置设为开始因为request和response读取完以后Position到最后一个位置,交给下一个方法处理的时候就会读不到内容了。*/stream.Position = 0;return result;}public string GetResponseValues(HttpActionExecutedContext actionExecutedContext){Stream stream = actionExecutedContext.Response.Content.ReadAsStreamAsync().Result;stream.Position = 0;Encoding encoding = Encoding.UTF8;/*这个StreamReader不能关闭,也不能dispose,因为你关掉后,后面的管道  或拦截器就没办法读取了*/var reader = new StreamReader(stream, encoding);string result = reader.ReadToEnd();/*这里也要注意:   stream.Position = 0; 当你读取完之后必须把stream的位置设为开始因为request和response读取完以后Position到最后一个位置,交给下一个方法处理的时候就会读不到内容了。*/stream.Position = 0;return result;}}

2.在控制器上方加上

[CustomActionFilter]

这样就可以方便打印日志啦

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/659343.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《Access Path Selectionin a Relational Database Management System》论文笔记

以下是根据论文归纳出的一些查询优化器公式和知识点&#xff0c;有没有用不知道&#xff0c;先码起来。 SQL执行优化过程 处理SQL语句是从解析用户输入的SQL语句开始&#xff0c;经过一系列优化过程&#xff0c;最终生成机器代码并执行的过程。这个过程涉及到多个复杂的步骤&…

FPS框架第二天

话说今天睡得很不错&#xff0c;足足睡了10小时&#xff0c;赶紧洗刷吃早餐&#xff0c;一切就绪后&#xff0c;想起来了我要做一款游戏&#xff0c;射击类游戏&#xff0c;因为我要超神&#xff0c;不要超鬼&#xff0c;说干就干&#xff0c;马上打开电脑&#xff0c;下载好un…

C++ 入门(三)— 函数

文章目录 函数简介函数返回值Void 函数&#xff08;非值返回函数&#xff09;函数参数和参数局部范围函数的声明和定义具有多个代码文件的程序 函数简介 C 程序的方式工作。当程序遇到函数调用时&#xff0c;它将在一个函数内按顺序执行语句。函数调用是告诉 CPU 中断当前函数…

AI的安全应答之道

作者&#xff1a;统信UOS技术团队 2023,随着各种大语言模型的爆发&#xff0c;整个AI生态正处于从决策式AI进化到生成式AI的进程中。各类AI模型和AI应用层出不穷&#xff0c;也随之带来了与AI相关的各类潜在风险。AI开发和使用过程中的风险防范和治理&#xff0c;成为了不可忽…

20240131 大模型快讯

//社区生态// 国内首个音视频多媒体大模型万兴“天幕”正式发布。万兴科技发布国内首个音视频多媒体大模型万兴“天幕”&#xff0c;支持多种语言&#xff0c;实现音视频创作闭环。 //行业落地// 全球首款搭载AI大模型的MPV智能座舱发布。江淮全新MPV瑞风RF8上市发布&#xf…

使用java流式API【 下划线转驼峰】和【驼峰转下划线】

使用java流式API【 下划线转驼峰】和【驼峰转下划线】 使用java流式API【 下划线转驼峰】和【驼峰转下划线】下划线转驼峰驼峰转下划线测试 使用java流式API【 下划线转驼峰】和【驼峰转下划线】 下划线转驼峰 /*** 下划线转驼峰* param str*/public static String underscor…

【20240131】USB相机(查看设备列表、打开设备)

USB相机采集 1、v4l2查看设备列表2、查看具体设备信息3、在桌面打开USB相机 1、v4l2查看设备列表 打开终端&#xff0c;输入&#xff1a;v4l2-ctl --list-devices usb设备在Webcam: Webcam栏&#xff0c;分别是video9和video10&#xff0c;下一步&#xff1a;确定哪一个是接入…

vue2将一个页面作为组件来展示

这里使用vue2进行的实现 首先先建一个页面 <template><div>我是标题块111</div></template><script> export default {name: "index" } </script><style scoped></style>建好了页面&#xff0c;接下来在需要将这个页…

华为mate60 pro与小米14 pro 的巅峰对决

今天我们换下思路&#xff0c;不讲技术了&#xff01;我们一起讲讲手机&#xff01;小编暂时充当一下业余的数码咖。 今天我们就讲讲华为mate60 pro和小米14pro 这两款手机。这两款手机都是近期新出的发行版本&#xff0c;热度那是一直未减啊。 华为mate60 Pro 我们先说说这个…

分布式搜索引擎_学习笔记_1

分布式搜索引擎01 – elasticsearch基础 0.学习目标 1.初识elasticsearch 1.1.了解ES 1.1.1.elasticsearch的作用 elasticsearch是一款非常强大的开源搜索引擎&#xff0c;具备非常多强大功能&#xff0c;可以帮助我们从海量数据中快速找到需要的内容 例如&#xff1a; …

01、全文检索 ------ 反向索引库 与 Lucene 的介绍

目录 全文检索 ------ 反向索引库 与 LuceneSQL模糊查询的问题反向索引库反向索引库的查询 Lucene&#xff08;全文检索技术&#xff09;Lucene能做什么Lucene存在的问题Solr 和 Elasticsearch 与 Lucene 的关系 全文检索 ------ 反向索引库 与 Lucene MySQL一些索引词汇解释 …

Android进阶之路 - ViewPager2 比 ViewPager 强在哪?

我记得前年&#xff08;2022&#xff09;面试的时候有被问到 ViewPager 和 ViewPager2 有什么区别&#xff1f;当时因为之前工作一直在开发售货机相关的项目&#xff0c;使用的技术要求并不高&#xff0c;所以一直没去了解过 ViewPager2~ 去年的时候正好有相关的功能需求&#…

09. BI - 数据可视化,如何进行基本图形绘制

本文为 「茶桁的 AI 秘籍 - BI 篇 第 09 篇」 文章目录 EDA 作用可视化视图Python 进行可视化subplot Hi&#xff0c;你好。我是茶桁。 今天想给大家讲的是关于数据的可视化。在工作中很多时候我们不光要计算结果&#xff0c;还要把结果呈现出来&#xff0c;最好是一种图形化的…

机器学习_无监督学习之聚类

文章目录 介绍机器学习下的分类K均值算法K值的选取:手肘法用聚类辅助理解营销数据贴近项目实战 介绍机器学习下的分类 以下介绍无监督学习之聚类 聚类是最常见的无监督学习算法。人有归纳和总结的能力&#xff0c;机器也有。聚类就是让机器把数据集中的样本按照特征的性质分组&…

vue + 动态加载图片

1、 适用于处理少量链接的资源文件 import img from ./img.png; <img :src"img" >2、图片在src目录下 vite官网的静态资源引入参考地址 new URL(url, import.meta.url) import.meta.url 是一个 ESM 的原生功能&#xff0c;会暴露当前模块的 URL。将它与原生的…

SpringBoot 使用WebSocket功能

实现步骤&#xff1a; 1.导入WebSocket坐标。 在pom.xml中增加依赖项&#xff1a; <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId> </dependency>2.编写WebSocket配…

深度学习有何新进展?

深度学习是人工智能领域一项重要的技术&#xff0c;在过去几年里有许多新的进展。 首先&#xff0c;一些研究人员提出了新的深度学习结构&#xff0c;如变分自编码器&#xff08;Variational Autoencoders, VAE&#xff09;和生成对抗网络&#xff08;Generative Adversarial …

Codeforces Round 922 (Div. 2)(A~D)补题

A题考虑贪心&#xff0c;要使使用的砖头越多&#xff0c;每块转的k应尽可能小&#xff0c;最小取2&#xff0c;最后可能多出来&#xff0c;多出来的就是最后一块k3&#xff0c;我们一行内用到的砖头就是 m 2 \frac{m}{2} 2m​下取整&#xff0c;然后乘以行数就是答案。 #inclu…

TCP四次握手

TCP 协议在关闭连接时&#xff0c;需要进行四次挥手的过程&#xff0c;主要是为了确保客户端和服务器都能正确地关闭连接。 # 执行流程 四次挥手的具体流程如下&#xff1a; 客户端发送 FIN 包&#xff1a;客户端发送一个 FIN 包&#xff0c;其中 FIN 标识位为 1&#xff0c…

小程序软件测试应该怎么做?有什么作用?

近年来&#xff0c;随着移动互联网的快速发展&#xff0c;小程序软件的使用越来越广泛。无论是企业推广还是个人创作&#xff0c;小程序软件都具备了很大的潜力和市场空间。然而&#xff0c;在发布之前&#xff0c;进行充分的测试是至关重要的&#xff0c;以确保用户体验的顺畅…