我需要以编程方式设置文件附加程序。我想在log4j2.xml上设置我的附加程序,但我想在运行时(以编程方式)仅写入这些附加程序之一。示例:if(condition.equals("A")){//writelogonFile_1}elseif(condition.equals("B")){//writelogonFile_2}else{//writelogonFile_3}查看Internet上的各种教程,他们解释了如何在运行时以编程方式添加附加程序;有没有办法选择在运行时只有xml配置文件中定义的附加程序之一?第一个解决方案:我已尝试通过以下方式解决问题,但我对我的解决方案并不满意,因
有谁知道如何使用log4j的配置xml为MDC中缺失的条目指定默认值?我在我的XML文件中定义了一个附加程序,如下所示:有问题的部分是来自MDC的订单ID(%X{orderID})。我四处搜索,只发现同一个线程的副本说了一些类似$${orderID:-DefaultValue}的内容,但这在这种情况下不起作用。当在没有订单ID的上下文中收到日志消息时,我需要能够将该值默认为0或-1或其他一些重要值 最佳答案 如果您在java代码中访问MDC对象,则可以通过在某些启动区域(例如,servletinit()方法)添加以下内容来初始化or
我正在使用与java.io.File实例一起使用的第三方库。我想在我的单元测试中使用这个库,但我不希望它在磁盘上创建文件。我的第一个想法是使用JimFs模拟文件系统,但它不支持java.io.File。我的第二个想法是使用一些模拟框架模拟File并将调用委托(delegate)给JimFs,但不知道这是否可行。是否有一些使用虚拟java.io.File的解决方案? 最佳答案 您可以使用JUnitTemporaryFolder规则轻松创建在测试方法完成后删除的临时文件。 关于java-使用
我正在使用适用于Java的GoogleAppEngine,并且正在尝试为处理blobstore的代码编写JUnit测试。如何将blob放入blobstore以在测试期间使用(在将其配置为使用LocalBlobstoreServiceTestConfig将所有内容保存在内存中之后)?看起来解决方案应该非常简单和基本,但不知何故我找不到。我认为可以使用FilesAPI,但我已经避开它,因为它(下周)将被停用。我知道将blob放入测试的blobstore外部的唯一方法是通过多部分表单上传。但是,我不知道如何在JUnit测试的上下文中执行此操作。也可以通过blobstoreAPI与Google
此代码搜索特定文件:StreamfindMyFile=Files.find(Paths.get("c:\\temp\\pathtest"),Integer.MAX_VALUE,(p,a)->p.endsWith("test.txt")&&a.isRegularFile());StreamfindMyFileSecond=Files.walk(Paths.get("c:\\temp\\pathtest"),Integer.MAX_VALUE).filter(p->p.endsWith("test.txt"));findMyFile.forEach(System.out::println)
在项目的pom.xml中,我看到如下所示的依赖项org.slf4jslf4j-api1.7.5org.slf4jslf4j-log4j121.7.5log4jlog4j1.2.17有人可以告诉我slf4j-log4j12和log4j之间有什么区别吗? 最佳答案 Log4j1.2slf4j-log4j12提供了SLF4J和Log4j1.2之间的桥梁,以便SLF4J知道如何使用Log4j进行日志记录。您正在使用Log4j1.2。该版本的绑定(bind)由SLF4J项目维护。这是来自theSLF4Jdocs的摘要:SLF4Jsupport
经过多次搜索,我终于认为我的问题的解决方案是问你。所以我的问题在于如何创建有关我的Web应用程序使用情况的日志。我找到了log4jjava库,但我不明白它是如何工作的。我必须在哪里创建配置文件?在哪里以及如何引用它?我可以创建一个连接到postgres并插入日志我的三个参数的类吗?这是我在网上找到的:./src/log4j/log4j.propertieslog4j.rootCategory=FATAL,CONSOLE#definitiondel'appenderconsolelog4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
我有一个项目A,其构建路径上有log4j.jar。我有许多具有以下形式的日志记录语句的类:Logger_log=Logger.getLogger(A..class);..._log.info("...");我正在将项目作为jar导出到另一个项目B。项目B已经有自己的log4jjar和它自己的.xml配置文件。我想配置A中的特定类以在不同的“级别”登录到控制台Apender。请问我该怎么做? 最佳答案 嗯,基本上,你不应该那样做。这样想:如果那样做,任何应用程序中包含的每个库都将托管自己的日志记录配置,很可能以非指定顺序覆盖应用程序中
我正在尝试使用log4j2为我正在开发的系统创建日志文件,我已经按照他们site上的说明进行操作当我运行它时没有发生错误,但日志没有保存在我设置的位置(例如“D:\logs\app.log”)。这是我的log4j.xml%d%p%C{1.}[%t]%m%n我试过:删除app.log以查看我的配置(D:\logs\app.log)是否有效。当我运行应用程序时,它会创建app.log,所以我认为这意味着它看到了配置,唯一的问题是它没有保存我在java应用程序中所做的log.info将根级别更改为“TRACE”,并打印log.info。[编辑:]我的类路径中也有这些库log4j-api-2.
我在我的OSX10.7.5上与Debian并行运行,我已经将一个包含Java源代码的目录从OSX链接到虚拟Debian机器(使用Parallels工具,它将目录挂载到/media/psf/)。编译工作正常,我遇到的唯一问题是MavenAssembly插件:它提示:Failedtoretrievenumericfileattributesusing:'/bin/sh-cls-1nlaR我用谷歌搜索了以下问题:http://jira.codehaus.org/browse/MASSEMBLY-588他们建议使用${baseDir}在jarlib.xml.通过此修改,代码可以编译,但是在使用