zoukankan      html  css  js  c++  java
  • ActionFilterAttribute 全局记录API日志

    1、API项目下创建MonitorApiAttribute

    public class MonitorApiAttribute : ActionFilterAttribute
        {
            private static readonly string key = "enterTime";
    
            public override void OnActionExecuted(HttpActionExecutedContext filterContext)
            {
                try
                {
                    object beginTime = null;
                    if (filterContext.Request.Properties.TryGetValue(key, out beginTime))
                    {
                        var user = HttpContext.Current.User as UserInfo;//登录时储存的User
                        var indentify = user != null ? user.Id.ToString() : null;
                       
                        MonitorApiHelper.Monitor(beginTime, filterContext.Request, filterContext.Response, indentify);
                    }
                }
                catch (Exception)
                {
                }
    
                base.OnActionExecuted(filterContext);
            }
    
            public override void OnActionExecuting(HttpActionContext actionContext)
            {
                actionContext.Request.Properties[key] = DateTime.Now.ToBinary();
    
                base.OnActionExecuting(actionContext);
            }
        }
    

    2、Common项目下创建MonitorApiHelper帮助类

    public class MonitorApiHelper
        {
           
    
            public static async void Monitor(object beginTime, HttpRequestMessage httpRequestMessage, HttpResponseMessage httpResponseMessage, string indentify = "", string moduleId = "")
            {
                DateTime time = DateTime.FromBinary(Convert.ToInt64(beginTime));
                var responseTime = Convert.ToInt32((DateTime.Now - time).TotalMilliseconds);
    
                var appId = "myapp";
                var clientType = 0;
                var responseStatus = 0;
    
                var request = HttpContext.Current.Request;
                var browerVersion = request.UserAgent;
                var clientIP = request.UserHostAddress;
                var serviceName = request.Url.AbsoluteUri;
                var requestType = MethodConver(request.HttpMethod);
    
                var inputParams = ReadStream(await httpRequestMessage.Content.ReadAsStreamAsync());
                var outputParams = ReadStream(await httpResponseMessage.Content.ReadAsStreamAsync());
    
                //在这里使用以上变量记录日志操作
            }
    
            private static int MethodConver(string method)
            {
                switch (method.ToUpper())
                {
                    case "GET":
                        return 0;
                    case "POST":
                        return 1;
                    case "PUT":
                        return 2;
                    case "DELETE":
                        return 3;
                    default:
                        break;
                }
                return 0;
            }
    
            public static string ReadStream(Stream stream)
            {
                var content = string.Empty;
                if (stream != null)
                {
                    stream.Seek(0, SeekOrigin.Begin);
                    int len = (int)stream.Length;
                    byte[] inputByts = new byte[len];
                    stream.Read(inputByts, 0, len);
                    stream.Position = 0;
                    content = Encoding.UTF8.GetString(inputByts);
                }
    
                return content;
            }
        }
    

    3、WebApiConfig下增加代码  config.Filters.Add(new MonitorApiAttribute());

      public static class WebApiConfig
        {
            public static void Register(HttpConfiguration config)
            {
                // Web API configuration and services
    
                // Web API routes
                config.MapHttpAttributeRoutes();
    
                config.Filters.Add(new MonitorApiAttribute());
    
                config.Routes.MapHttpRoute(
                    name: "DefaultApi",
                    routeTemplate: "api/{controller}/{id}",
                    defaults: new { id = RouteParameter.Optional }
                );
            }
        }
    
  • 相关阅读:
    模块化+定制化,PIX赋能多种行业实现低速无人车商业化
    支持Apollo、Autoware,PIX推出自动驾驶开发套件PIXKIT
    专为自动驾驶开发者打造的线控底盘——PIXLOOP
    甄别信息、病毒追踪、无人配送...这9个全球开源工具助力疫情抗击
    PIX无损线控改装——全系列车型及性能介绍
    PIX线控改装技术连载二 | 车辆组成模块之间的共同语言
    PIX入选Autodesk硅谷技术中心,以生成设计和金属增材制造落地L4自动驾驶通用底盘
    线控CRV,最高性价比的自动驾驶开发平台
    线控改装技术连载一之——线控开端和车辆组成
    CSS 创建
  • 原文地址:https://www.cnblogs.com/lizhenhong/p/9591470.html
Copyright © 2011-2022 走看看