WPF 应用程序中的 Log4Net 设置

2024-01-11

我不敢相信我不得不问这个,但这里是......

我正在尝试在新的 WPF 应用程序中设置 log4net,但由于某种原因,它没有创建日志文件并记录任何内容,所以这是我到目前为止所做的步骤...

添加来自 nuget 的最新版本(v2.0.8.0)参考后。

在 AssemblyInfo.cs 中:

 [assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4Net.config", Watch = true)]

在应用程序配置中:

  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net, Version=2.0.8.0, Culture=neutral, PublicKeyToken=669e0ddf0bb1aa2a" />
  </configSections>
  <log4net configSource="Log4Net.config" />

在 Log4Net.config 中:

<?xml version="1.0" encoding="utf-8"?>
<log4net>
  <appender name="rollingLogFile" type="log4net.Appender.RollingFileAppender">
    <file value="D:\Logs\WorkflowApp.log" />
    <appendToFile value="true" />
    <rollingStyle value="Size" />
    <maxSizeRollBackups value="10" />
    <maximumFileSize value="100KB" />
    <staticLogFileName value="true" />
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date [%thread] %-6level %logger - %message %exception%newline" />
    </layout>
  </appender>
  <root>
    <level value="DEBUG" />
    <appender-ref ref="rollingLogFile" />
  </root>
</log4net>

在 App.xaml.cs 中:

ILog log = LogManager.GetLogger(typeof(App));

protected override void OnStartup(StartupEventArgs e)
{
    base.OnStartup(e);
    log.Debug("Initialising ...");
}

作为最后一个“尝试一下,看看它是否有效”,我将其添加到上述方法中......

XmlConfigurator.Configure();

...仍然没有创建长文件。

那么我错过了什么?

EDIT:

所以根据评论,我想我应该添加以下内容:

我见过这样的问题和答案......使用 log4net 写入不同的记录器 https://stackoverflow.com/questions/17106559/using-log4net-to-write-to-different-loggers

...如果我将这样的内容添加到我的 Log4Net.config 中...

  <logger name="File">
    <level value="DEBUG" />
    <appender-ref ref="rollingLogFile" />
  </logger>

然后将我的记录器构造更改为...

ILog log = LogManager.GetLogger("File");

...然而,这仍然导致什么也没有发生,没有日志文件,但没有异常,并且除了似乎执行但没有结果的日志记录调用之外,代码似乎运行良好。


如果你是DEV,你需要将Log4Net.config复制到bin\debug中;做了还是没做?必须将副本设置为属性,或者作为稍后包含在安装程序中的资源文件。再见;感谢您的投票。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

WPF 应用程序中的 Log4Net 设置 的相关文章

随机推荐

  • F#(或.NET 库)的统计功能

    从事统计工作的人是否可以用 F 代替他的专业程序 我主要考虑SAS SPSS F 中有对它的本机支持吗 我不是在谈论标准差之类的琐碎事情 而是例如项目响应建模 更新 不要让项目响应模型让你失望 我什至不知道 只是我知道他们使用 SPSS 所
  • JavaScript 中的反向事件冒泡

    如您所知 事件通常在 JavaScript 中冒泡 因此首先执行触发事件的元素的事件处理程序 然后调用父元素的事件处理程序 依此类推 这种行为会导致我当前正在处理的项目出现一些问题 我宁愿颠倒执行顺序 我想出了一个使用超时的解决方案 ele
  • 如何使用属性的 getter 方法上的 @XMLElement 覆盖在类级别指定的 JAXB @XMLAccessorType(XMLAccessType.FIELD)?

    在下面的示例代码中 Employee已使用 JAXB 字段级别访问类型指定了类 对于物业dept 但是 访问类型已在 getter 方法级别指定为 XMLElement注解 在编组期间组织类 抛出以下异常 com sun xml inter
  • Spring连接池问题

    我对 Java 和 Spring 没有经验 我尝试编写一个使用 JdbcTemplate 进行数据访问的程序 我使用DBCP池 这里是
  • ObjC、Facebook 页面 - 发布新闻源有效,但发布照片无效

    所以我试图从 iPhone 应用程序在我的 Facebook 页面 我是管理员 上发布照片 我正在使用 FB Sessions 创建会话 获取读取权限 获取管理页面权限 然后 我成功获取我的 Facebook 页面应用程序 ID 因为 FB
  • Android 谷歌云消息传递示例无法正常工作

    我正在关注这里的教程http developer android com google gcm gs html http developer android com google gcm gs html为了设置 GCM 我目前正在尝试注册设
  • AMO OLAP 查询绑定

    根据业务逻辑 有时我需要更改多维数据集中的客户维度的源表 以前我使用以下代码更改多维数据集的结构 MyServerDataSourceView Schema Tables DimCustomers ExtendedProperties Qu
  • 提高 R 代码有效性的技巧

    我正在使用 Reddit 的 API Pushshift 编写一个循环 在 R 中 来抓取 Reddit 帖子 本质上 我希望每小时获取从现在到 20 000 小时前包含 特朗普 一词的所有评论 API 将注释存储在 JSON 框架中 我在
  • python 脚本的 setuid/setgid 包装器

    我有一个 Python 脚本 我希望能够以系统用户身份运行guybrushUID 200 和组guybrushGID 200 目前我的Python脚本 位于 path to script py 看起来像这样 usr bin env pyth
  • 嵌入 Youtube 播放列表,但从随机视频开始

    我已经做了很多搜索 但到目前为止找不到解决方案 我有一个 YouTube 播放列表 我想将其嵌入到网站上 但我不想总是从第一个视频开始 而是希望它从随机视频或至少一个特定视频开始 我可以使用服务器端代码随机选择 我查看了 iframe 嵌入
  • 切换类并从所有其他元素中删除类

    如何切换类并从所有其他元素中删除类 考虑一个包含标签的 div html div class size a href blahblah a a href blahblah a div jQuery size a click function
  • RStudio:在编写 RMarkdown 文档时禁用源窗口中代码的输出

    我最近更新了 RStudio 在源窗口中编写 R Markdown 文档时 每当我在 RMD 块中运行代码时 输 出都会以以下方式显示在源窗口本身中 当有巨大的情节时 它会变得太混乱 如果可能的话 希望禁用此功能并恢复为仅在控制台 绘图查看
  • 如何防止 Javadoc 中出现包私有接口?

    我有一堂这样的课 package org jjerms thing interface IThing void doSomething final class Thing implements IThing This Javadoc pre
  • DeleteFile 对最近关闭的文件失败

    我有一个单线程程序 C Win32 NTFS 它首先创建一个相当长的临时文件 关闭它 打开读取 读取 再次关闭并尝试使用删除DeleteFile 通常情况下进展顺利 但有时DeleteFile 失败 并且GetLastError 返回 ER
  • WTForms 使用 SelectField“解压太多值”

    我正在使用 WTForms 我正在尝试显示SelectField 但我收到以下错误 gt gt gt form status Traceback most recent call last File
  • boost::asio get_io_service() boost 1.70+ 中的替代方案

    我想使用一个图书馆 https github com onlinecity cpp smpp https github com onlinecity cpp smpp 并且它基于 boost 1 41 但在我们的项目中 我们使用的是 1 7
  • 当应用程序在后台或未运行时,推送通知无法正常工作

    我正在使用 Firebase Cloud Messaging 发送推送通知 这是我的FirebaseMessageService public class FireBaseMessageService extends FirebaseMes
  • 是否可以使用 jQuery 来调用 Google 地图 API?

    以下不起作用 get http maps googleapis com maps api geocode json sensor false region nz address queen function response console
  • 是否有可能在任何地方抛出异常的 STL 容器方法列表?

    我知道 STL 会抛出内存分配错误 或者如果包含的类型在其构造函数 赋值运算符中抛出异常 否则 显然 一些 STL 方法可能会引发其他异常 每个人似乎都提到的示例是 vector at 但我在任何地方都找不到其他示例的列表 有谁知道这样的清
  • WPF 应用程序中的 Log4Net 设置

    我不敢相信我不得不问这个 但这里是 我正在尝试在新的 WPF 应用程序中设置 log4net 但由于某种原因 它没有创建日志文件并记录任何内容 所以这是我到目前为止所做的步骤 添加来自 nuget 的最新版本 v2 0 8 0 参考后 在