webapi 接受写入log文件_webapi log4net 设置写入txt 文件 - CSDN
精华内容
参与话题
  • Web APILog问题

    2019-01-05 10:52:24
    建立了一个Web API项目,在WebApiConfig.cs中已经启用了Tracing. config.EnableSystemDiagnosticsTracing(); 同时web.config中也已经配置了TextWriter. <system.diagnostics> &lt...

    建立了一个Web API项目,在WebApiConfig.cs中已经启用了Tracing.

    config.EnableSystemDiagnosticsTracing();

    同时web.config中也已经配置了TextWriter.

    <system.diagnostics>

    <trace autoflush="true" indentsize="4">

    <listeners>

    <add name="myListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="WebApiLog.log" />

    <remove name="Default" />

    </listeners>

    </trace>

    </system.diagnostics>

     

    然后在具体的代码中记录了Log.

    Trace.WriteLine("my message");

     

    可是web api被调用后却没有log文件出现,怎么回事那?

    【分析】

    这是因为web api网站的应用程序池账号对物理目录没有写权限,所以无法写log.

    【解决方法】

    Grant IIS APPPOOL\<application pool name> at least Edit permission for the web api web site's physical folder.

     

     

    展开全文
  • webApi log4net.config

    2019-01-14 16:21:54
    webApi log4net.config 我们为 WebAPI 添加 log4net 日志功能, LogNet 的配置信息, 网络几乎都是和 Web.Config 写在一起啊的 。 由于强迫症 我单独出来,但是又没找到 从哪里 初始化 这个 配置信息 后来 ...

                                  webApi    log4net.config

    我们为 WebAPI  添加 log4net 日志功能,

    LogNet 的配置信息,  网络几乎都是和 Web.Config  写在一起啊的 。

    由于强迫症 我单独出来,但是又没找到 从哪里 初始化 这个 配置信息

    后来 找到了

    //为项目注册 Log4Net.config
    [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]

    Log4Net.config

    <?xml version="1.0" encoding="utf-8"?>
    <configuration>
    
      <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
      </configSections>
      
      <system.web>
        <compilation debug="true" targetFramework="4.6.1" />
        <httpRuntime targetFramework="4.6.1" />
      </system.web>
      
      
      <log4net>
        <!-- OFF, FATAL, ERROR, WARN, INFO, DEBUG, ALL -->
        <!-- Set root logger level to ERROR and its appenders -->
        <root>
          <level value="ALL" />
          <appender-ref ref="SysAppender" />
        </root>
        <!-- Print only messages of level DEBUG or above in the packages -->
        <logger name="WebLogger">
          <level value="DEBUG" />
        </logger>
        <appender name="SysAppender" type="log4net.Appender.RollingFileAppender,log4net">
          <param name="File" value="App_Data/" />
          <param name="AppendToFile" value="true" />
          <param name="RollingStyle" value="Date" />
          <param name="DatePattern" value="&quot;Logs_&quot;yyyyMMdd&quot;.txt&quot;" />
          <param name="StaticLogFileName" value="false" />
          <layout type="log4net.Layout.PatternLayout,log4net">
            <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />
          </layout>
        </appender>
        <appender name="consoleApp" type="log4net.Appender.ConsoleAppender,log4net">
          <layout type="log4net.Layout.PatternLayout,log4net">
            <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />
          </layout>
        </appender>
      </log4net>
      
      
    </configuration>
    

    展开全文
  • .net web api 记录日志

    2015-04-22 09:44:45
    想找个方便的。 理论上是有处理结束时,然后做统一处理。请求的内容即结束时返回的内容。 最好能判断是否错误等
  • WebAPI+NLog实现接口调用日志输出

    千次阅读 2017-05-16 23:22:05
    在生产环境下,经常需要监测查看WebAPI接口的调用情况,日志就成了必不可少的手段之一,本文采用NLog实现WebAPI的日志记录。 创建WebAPI创建WebAPI项目,选择ASP.NET 4.5.2模板中的WebAPI模板。 引用NLog类库

    在生产环境下,经常需要监测查看WebAPI接口的调用情况,日志就成了必不可少的手段之一,本文采用NLog实现WebAPI的日志记录。

    环境 版本
    操作系统 Windows 10 prefessional
    编译器 Visual Studio 2015 update3

    创建WebAPI

    创建WebAPI项目,选择ASP.NET 4.5.2模板中的WebAPI模板。
    这里写图片描述

    引用NLog类库

    打开项目的NuGet包管理器,搜索NLog,为项目添加程序包引用。
    这里写图片描述

    修改项目配置文件

    在webAPI项目的Web.config中进行NLog的配置。首先在节点configuration>configSections下添加节点:
    这里写图片描述

    此处name必需为nlog,否则配置信息将不能被读取。
    然后在configuration节点下添加节点nlog:
    这里写图片描述

    这里定义了日志文件的保存路径、命名格式以及日志记录类型和监听级别。

    创建日志跟踪相关类

    创建日志跟踪类AppLog,继承于System.Web.Http.Tracing下的跟踪编写器接口ITraceWriter,用于日志生成和写入:

        public sealed class AppLog : ITraceWriter
        {
            //日志写入
            private static readonly Logger AppLogger = LogManager.GetCurrentClassLogger();
            private static readonly Lazy<Dictionary<TraceLevel, Action<string>>> LoggingMap = new Lazy<Dictionary<TraceLevel, Action<string>>>(() => new Dictionary<TraceLevel, Action<string>>
            {
                {TraceLevel.Info,AppLogger.Info },
                {TraceLevel.Debug,AppLogger.Debug },
                {TraceLevel.Error,AppLogger.Error },
                {TraceLevel.Fatal,AppLogger.Fatal },
                {TraceLevel.Warn,AppLogger.Warn }
            });
    
    
            private Dictionary<TraceLevel, Action<string>> Logger
            {
                get { return LoggingMap.Value; }
            }
            /// <summary>
            /// 跟踪编写器接口实现
            /// </summary>
            /// <param name="request"></param>
            /// <param name="category"></param>
            /// <param name="level"></param>
            /// <param name="traceAction"></param>
            public void Trace(HttpRequestMessage request, string category, TraceLevel level, Action<TraceRecord> traceAction)
            {
                if (level != TraceLevel.Off)//未禁用日志跟踪
                {
                    if (traceAction != null && traceAction.Target != null)
                    {
                        category = category + Environment.NewLine + "Action Parameters : " + JsonConvert.SerializeObject(traceAction.Target);
                    }
                    var record = new TraceRecord(request, category, level);
                    if (traceAction != null)
                    {
                        traceAction(record);
                    }
                    //  traceAction?.Invoke(record);
                    Log(record);
                }
                //throw new NotImplementedException();
            }
            /// <summary>
            /// 日志写入
            /// </summary>
            /// <param name="record"></param>
            private void Log(TraceRecord record)
            {
                var message = new StringBuilder();
    
                /**************************运行日志****************************/
    
                if (!string.IsNullOrWhiteSpace(record.Message))
                {
                    message.Append("").Append(record.Message + Environment.NewLine);
                }
    
                if (record.Request != null)
                {
                    if (record.Request.Method != null)
                    {
                        message.Append("Method : " + record.Request.Method + Environment.NewLine);
                    }
    
                    if (record.Request.RequestUri != null)
                    {
                        message.Append("").Append("URL : " + record.Request.RequestUri + Environment.NewLine);
                    }
    
                    if (record.Request.Headers != null && record.Request.Headers.Contains("Token") && record.Request.Headers.GetValues("Token") != null && record.Request.Headers.GetValues("Token").FirstOrDefault() != null)
                    {
                        message.Append("").Append("Token : " + record.Request.Headers.GetValues("Token").FirstOrDefault() + Environment.NewLine);
                    }
                }
    
                if (!string.IsNullOrWhiteSpace(record.Category))
                {
                    message.Append("").Append(record.Category);
                }
    
                if (!string.IsNullOrWhiteSpace(record.Operator))
                {
                    message.Append(" ").Append(record.Operator).Append(" ").Append(record.Operation);
                }
    
                //***************************异常日志***********************************//
                if (record.Exception != null && !string.IsNullOrWhiteSpace(record.Exception.GetBaseException().Message))
                {
                    var exceptionType = record.Exception.GetType();
                    message.Append(Environment.NewLine);
                    message.Append("").Append("Error : " + record.Exception.GetBaseException().Message + Environment.NewLine);
    
                }
    
    
                //日志写入本地文件
                Logger[record.Level](Convert.ToString(message) + Environment.NewLine);
            }
        }

    创建日志筛选器类LogFilterAttribute,继承于System.Web.Http.Filters下的筛选器特性基类,用于定义日志内容:

        public class LogFilterAttribute : ActionFilterAttribute
        {
            public override void OnActionExecuting(HttpActionContext actionContext)
            {
                GlobalConfiguration.Configuration.Services.Replace(typeof(ITraceWriter), new AppLog());
                var trace = GlobalConfiguration.Configuration.Services.GetTraceWriter();
                trace.Info(actionContext.Request, "Controller : " + actionContext.ControllerContext.ControllerDescriptor.ControllerType.FullName + Environment.NewLine + "Action : " + actionContext.ActionDescriptor.ActionName, "JSON", actionContext.ActionArguments);
                //base.OnActionExecuting(actionContext);
            }
        }

    创建异常筛选器类AbnormalFilterAttribute,继承于System.Web.Http.Filters下的异常筛选器类,用于异常信息的跟踪筛选:

        public class AbnormalFilterAttribute: ExceptionFilterAttribute
        {
            public override void OnException(HttpActionExecutedContext actionExecutedContext)
            {
                GlobalConfiguration.Configuration.Services.Replace(typeof(ITraceWriter), new AppLog());
                var trace = GlobalConfiguration.Configuration.Services.GetTraceWriter();
                trace.Error(actionExecutedContext.Request, "Controller : " + actionExecutedContext.ActionContext.ControllerContext.ControllerDescriptor.ControllerType.FullName + Environment.NewLine + "Action : " + actionExecutedContext.ActionContext.ActionDescriptor.ActionName, actionExecutedContext.Exception);
                var exceptionType = actionExecutedContext.Exception.GetType();
                if (exceptionType == typeof(ValidationException))
                {
                    var resp = new HttpResponseMessage(HttpStatusCode.BadRequest) { Content = new StringContent(actionExecutedContext.Exception.Message), ReasonPhrase = "ValidationException" };
                    throw new HttpResponseException(resp);
                }
                else if (exceptionType == typeof(UnauthorizedAccessException))
                {
                    throw new HttpResponseException(actionExecutedContext.Request.CreateResponse(HttpStatusCode.Unauthorized));
                }
                else
                {
                    throw new HttpResponseException(actionExecutedContext.Request.CreateResponse(HttpStatusCode.InternalServerError));
                }
                //base.OnException(actionExecutedContext);
            }
        }

    应用NLog配置

    最后需要将上述配置应用到项目中去,在pp_Data>WebApiConfig中添加如下配置:
    这里写图片描述


    将上述步骤完成后,运行项目,调用API接口进行测试,调用完成后就可以在站点目录下找到日志文件,能够为API接口的日常运行维护提供很大的便利。

    展开全文
  • C# Log4net无法正常输出日志

    千次阅读 2018-10-14 19:39:40
    本人初学Log4net,一开始在网上查了很多资料,看了很多相关博客,自己在本地新建了一个Asp.Net的webapi项目,搭好相关环境之后,开始配置log4net,发现配置文件没有问题,程序也没有报错,但是日志无法正常输出。...

            本人初学Log4net,一开始在网上查了很多资料,看了很多相关博客,自己在本地新建了一个Asp.Net的webapi项目,搭好相关环境之后,开始配置log4net,发现配置文件没有问题,程序也没有报错,但是日志无法正常输出。

    解决方案

    [assembly:log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", ConfigFileExtension = "config", Watch = true)] 查看这个标注是否放错了位置,需要放在编写log4类里面,不能放在调用端

    具体代码步骤如下:

    1、从官网下载log4net文件,下载地址http://logging.apache.org/log4net/download_log4net.cgi

    2、将下载的文件,解压,得到 log4net.dll文件

    3、在项目中引用此文件,如图:

    4、项目底下新建 log4net.config配置文件,具体配置如下:

    5、编写代码

    6、进行单元测试

    7、查看生成的错误日志(单元测试项目下,bin-debug-log文件夹下)

     

     

    展开全文
  • 1、添加jar包:log4j.jar;slf4j-api-1.5.0.jar;slf4j-log4j12-1.5.0.jar。 2、
  • 搭建WebApi框架步骤

    万次阅读 2016-11-15 16:39:44
    1、 打开vs-文件-新建项目-web-Asp.net Web应用程序-确定-Web Api-Mvc Web API-确定 2、 查看项目Controller文件夹,下面两个文件: HomeController.cs—–打开该文件,该文件继承的是Controller.(继承MVC里的...
  • slf4j无法写入日志文件问题

    千次阅读 2018-07-19 12:52:51
    最近自己写了java(非web)一个工程,突然发现我打印的日志都没有写到文件中,这让我纠结了很久。 先看看我有问题工程pom的配置: &lt;dependencies&gt; &lt;dependency&gt; &lt;groupId&...
  • WebApi》----将异常堆栈信息写入日志文件

    千次阅读 热门讨论 2016-08-10 14:03:03
    以前我们的程序如果在开发中出现错误,我们可以轻松捕获异常信息,但是如果是程序在服务器上运行,并且是生产环境的... 小编做的项目目前服务器程序运行的是WebApi,我们可以写一个日志类,此类可以将错误的堆栈信
  • Node读取和写入json,格式化输出json

    万次阅读 2018-03-07 15:38:40
    现在需要一个写一个脚本,处理两个json文件,把Bjson文件在A中没有的中文词条都要找出来写入另外一个json,实际需求要复杂得多,先写个初步demo: var fs = require('fs'), path = require('path'); let ans...
  • 如何向系统写入Event Log

    千次阅读 2005-07-14 18:02:00
    Event Log机制分析:解决方案:1:.NET部署WebService写Event Log到System .NET中提供了功能强大的EventLog类,可以很方便的写入,WebService集中式部署,管理也很方便。 可是不足的是WebService权限的问题,每次...
  • WebAPI+SignalR实现实时日志监测

    千次阅读 2017-05-17 00:56:21
    在最近的一篇博文中描述了使用NLog记录WebAPI的调用日志,但是也发现在实际使用中由诸多不便。日志只有在生成后才能查看,能否在接口调用的同时就看到呢?结合使用SignalR可以实现这种可能。 本文会在之前的两篇...
  • WEB API Html5 读取写入txt

    千次阅读 2019-09-27 11:15:40
    使用HTML5来实现本地文件读取和写入 原创2015年12月11日 17:06:34 ...说白了,就是一件事,就是如何读取或写入本地文件系统中的文件。 这件事情在HTML5以前是一件非常恐怖的,因为浏览器对本地...
  • 摘自:...   错误: Server Error in '/' Application. -------------------------------------------------------------------------------- ...Configuration Err
  • PHP错误日志

    万次阅读 2013-07-18 16:52:53
    转载自:http://hi.baidu.com/kity456/item/7e1be8a0f01f90aa28ce9d23 对于PHP开发者来说,一旦...但是,任何一个产品在投入使用后,都难免会有错误出现,那么如何记录一些对开发者有用的错误报告呢?我们可以在单独
  • Resin中对日志输出的配置

    万次阅读 2011-04-26 21:56:00
    前两个放在标签,也就是主标签下面,其中log主要用于配置JDK logging API,logger用于指定需要log的包及level,跟log4j中的用法相似,只不过resin中level有个特殊的选项就是off,用于关闭日志输出;而后面三个*-log...
  • 前面一直在说,如何读取到log4j 的配置文件 log4j.properties。 接下来的探讨的是: log4j 里配置产生的log 文件的路径如何设置。
  • 传统存储是 SAN 或者 NAS,提供了集中化、低延时的块存储或者文件系统,以支持TB级数据。在面对关系型数据库之类的服务时,这是很好的选择。但是面对上万台计算机同时提取几百TB的数据时,这种集中型存储就难以胜任...
  • 同时,通过外部配置文件,用户可以不用重新编译程序就能改变应用的日志行为,使得用户可以根据情况灵活地选择要记录的信息。 那么我们如何在Web项目中使用Log4Net呢? 1、下载Log4Net,地址如下:...
  • HTML5之本地文件系统API - File System API

    万次阅读 2014-06-03 17:54:57
    HTML5之本地文件系统API - File System API ...File System API,它能够帮助我们来突破沙箱访问我们本地的文件系统,从而有效的弥补桌面和web应用之间的鸿沟。在今天这篇文章中,我们将会介绍基本
1 2 3 4 5 ... 20
收藏数 38,186
精华内容 15,274
关键字:

webapi 接受写入log文件