草庐IT

log4j-defaults

全部标签

c# - 3rd 方库引用不同版本的 log4net.dll

我有两个对我的应用程序至关重要的库,它们依赖于不同版本的log4net.dll。当我正在使用的第3方部分被调用时,在我的bin文件夹中尝试这两个dll会出现通常的错误:无法加载文件或程序集“log4net,Version=1.2.10.0,Culture=neutral,PublicKeyToken=1b44e1d426115821”或其依赖项之一。找到的程序集的list定义与程序集引用不匹配。(HRESULT异常:0x80131040)有没有一种方法可以让应用程序同时引用这两个dll?第三方dll是Windsor的IOC容器和Paypal的API,两者都对这个应用程序至关重要。

c# - 串行日志 : Log to different files

我正在将所有类型的事件记录到单个Json文件中,而不管LogLevel。现在我需要将一些自定义性能计数器记录到单独的Json文件中。如何在Serilog中完成此操作。我是否应该创建不同的记录器实例并在我要记录性能计数器的地方使用它?想将其与LibLog一起使用 最佳答案 您可以通过首先确保性能计数器事件标记有特定属性值(LibLog中的OpenMappedContext())或来自特定类型/命名空间来执行此操作。varlog=LogProvider.For()log.Info(...);配置Serilog时,一个sub-logger

c# - Log4Net 在单独的配置文件中

我需要为一个新项目配置log4net。当我将所有信息保存在App.config文件中时,一切正常。我想把log4net的配置放在一个单独的配置文件中(拿App1.config)这是我的app.config完美运行:我删除了除之外的所有内容从我的app.config元素并将其放入我的app1.config中:在我的Program.cs类中,我用这样的程序集调用配置:[assembly:log4net.Config.XmlConfigurator(ConfigFile="App1.config",Watch=true)]但是当我使用App1.config时,我的文件中没有日志。

c# - 如何在运行时添加 log4net appender?

如何在运行时添加额外的日志附加程序?(所有预先存在的附加程序必须继续工作)我正在尝试这种方式:varlayout=newPatternLayout("%utcdate%-5level-%message%newline");layout.ActivateOptions();_log4netAppender=newFileAppender{Layout=layout,File=logFilePath,};_log4netAppender.ActivateOptions();BasicConfigurator.Configure(_log4netAppender);但它不会向文件写入任何内容

c# - log4net 输出文件但不输出到调试窗口

我正在尝试获取错误的输出以显示在附加的日志文件中以及调试窗口中。日志文件工作正常,但调试窗口中什么都没有显示。首先,这是我的配置然后我在我的代码中调用log4netlog.Debug("Debugerrorlogging",ex);log.Info("Infoerrorlogging",ex);log.Warn("Warnerrorlogging",ex);log.Error("Errorerrorlogging",ex);log.Fatal("Fatalerrorlogging",ex);这在我的日志文件中创建了5个条目,但在我的控制台窗口中没有条目。我还修改了我的web.confi

c# - Properties.Settings.Default.Save(); ->那个文件在哪里

我有一个使用“设置”的应用。要保存我使用的设置:Properties.Settings.Default.Save();阅读我使用的:Properties.Settings.Default.MyCustomSetting;在我的应用程序文件夹中,我只有exe文件。没有配置文件。我的应用程序运行良好,可以读写设置。如果该文件不在应用程序文件夹中,该文件位于何处? 最佳答案 在我的WindowsXP机器上,设置保存在C:\DocumentsandSettings\\ApplicationData\下某处名为user.config的文件中。

c# - 如何判断用户访问的是 "/Default.aspx"还是 "/"

我正在我的Global.asax.cs的Application_BeginRequest部分中编写。出于SEO目的,我正在尝试重定向正在查看的用户:http://www.example.com/Default.aspx到:http://www.example.com/我的问题是:我如何知道用户正在看哪个?我一直在使用:HttpContext.Current.Request.Url.*但是无论我访问哪一个,所有参数都是相同的。 最佳答案 您可以获取在用户浏览器中输入的路径:stringpath=Request.RawUrl;MSDN

c# - 为什么 List<T>.Sort 使用 Comparer<int>.Default 比等效的自定义比较器快两倍以上?

结果使用1000万个随机列表ints(每次相同的种子,重复10次的平均值):listCopy.Sort(Comparer.Default)需要314毫秒。使用sealedclassIntComparer:IComparer{publicintCompare(intx,inty){returnxlistCopy.Sort(newIntComparer())需要716毫秒。一些变化:使用structIntComparer而不是sealedclass:771毫秒使用publicintCompare(intx,inty){returnx.CompareTo(y);}:809毫秒评论Compar

c# - 在 switch case 中,如果我们将 "default"写为任何单词或单个字母,它不会抛出错误

在switch中,如果我们写任何单词或单个字母而不是default,它不会抛出错误。例如switch(10){case1:break;hello:break;}它运行时没有抛出错误。谁能解释一下这是如何工作的? 最佳答案 它正在编译,因为hello:是一个标签,因此可以作为goto的目的地。当我编译这个时,我收到了关于未引用标签的警告(因为我没有转到)这是您可以放入LINQPad的示例-您会注意到它同时打印“1”和“hello”:switch(1){case1:"1".Dump();gotohello;break;hello:"he

c# - GDPR : Encrypted logging in C#

加密日志文件作为保护其中可能包含的个人数据的一种方法的建议很普遍。我还没有看到一个很好的引用实现,考虑到有多少公司需要它,这令人惊讶。在我们的特殊情况下,我们希望使用公钥加密,这样文件就无法在生成它们的(保护较弱的)系统上读取,并且必须被发送回我们可以查看它们的总部。到目前为止,我看到的最好的建议是“使用log4net,但使用来自BouncyCaSTLe的RFC3852流式实现来编写您自己的附加程序”。有人对此有进展吗? 最佳答案 从技术上讲,加密您的日志消息应该非常容易。使用像Serilog这样的东西你可以简单地创建一个custo