我有一个应用程序需要写入两种不同类型的日志:应用程序日志和审计日志。应用程序日志用于调试目的,而审计日志用于记录执行的操作。两个日志将在不同的文件中,每个文件应该只有提到的那些日志(意味着审计日志文件不能有应用程序日志,反之亦然)。这如何使用log4j实现?我知道实现这一点的一种方法是在log4j中定义自定义日志级别。还有其他/更好的方法吗? 最佳答案 我有过相同的用例。在您的log4j.xml中,您可以为每个定义两个不同的记录器和一个附加程序。因此,一个例子:在您的Java代码中,您可以使用“Logger.getLogger("L
我有一个使用java.util.Date类创建日期对象并使用getTime()获取当前毫秒数的类。我在Java文档中看到getTime()返回毫秒,我的机器上也有同样的情况。我有另一台服务器,当我在服务器上部署我的应用程序时,相同的getTime()以秒为单位返回时间戳。例如服务器上的值:1350054625本地值:1350054625000我想知道这怎么可能,我在本地尝试了相同的代码,但我再次获得了以毫秒为单位的时间戳。下面是部分代码...StringlongTime=newLong((newDate().getTime())).toString();if(log.isDebugEn
我正在使用Java1.7和Log4j2(beta9),并且我有以下log4j2.xml文件:%-5p-%m%n"/>%-5p-%m%n"/>就日志记录本身而言,它满足了我的需要。作为错误/异常序列的一部分,我需要发送一封带有日志文件附件的电子邮件。如何以编程方式获取“fileName="logs/foo.log"”位?我真的不想对此进行硬编码。 最佳答案 从Logger中,遍历所有getAllAppenders寻找实现RollingFileAppender的那个,然后调用getFile在上面。或者您可以使用getAppender("
我是第一次尝试使用SLF4J-Log4j。在每个Java类中,我都定义了一个记录器,如下所示:privateorg.slf4j.Loggerlogger=org.slf4j.LoggerFactory.getLogger(.class);(当然,我确保slf4-log4j12-1.6.4.jarJAR在类路径中!)但是每当我去使用记录器时,比如logger.debug("Somethinginterestinghappened");或logger.error("Anerroroccurred");,我没有在我的日志文件中看到它们的输出。然而,没有发生异常,应用程序(它实际上是一个部署到
我正在开发GWT应用程序。它使用RPC从内部系统收集信息。它通过使用库jar来实现,我们称它为alpha.jar。我们在许多应用程序中使用这个jar,所以它工作正常,顺便说一句,它是用ANT构建的,在eclipse之外。alpha.jar中的一些类引用LOG4J2以及许多其他外部jar,因此当我们运行一个应用程序时,我们将类路径传递给所有这些类,一切正常。请注意,这不是一个简单的初学者问题。alpha.jar正常工作,包括对Log4J的调用。问题:在Eclipse中,我有这个GWT应用程序项目和Alpha.jar项目(当然还有源代码)。服务器部分需要实例化alpha对象并与alpha系
如何获取log4j2中使用的所有记录器?在log4j中,我可以像这里描述的那样使用getCurrentLoggers:Numberofloggersused 最佳答案 获取log4j2中使用的所有记录器:LoggerContextlogContext=(LoggerContext)LogManager.getContext(false);Mapmap=logContext.getConfiguration().getLoggers();注意:使用org.apache.logging.log4j.core.LoggerContext不
我想将java.util.Date转换为java.sql.Date但我还需要小时、分钟和秒,但java.sql.Date可以仅用于存储日期(无时间)。我尝试了下面的代码,但它只给出了java.sql.Date对象的年、月和日。SimpleDateFormatformat=newSimpleDateFormat("yyyyMMddHHmmss");Dateparsed=format.parse("20110210120534");System.out.println(format.parse("20110210120534"));java.sql.Datesql=newjava.sql.
如何将javax.mail.SessionsetDebugOut重定向到log4j记录器?是否可以仅将mailSession调试重定向到记录器?我的意思是,有类似的解决方案linktext将所有标准输出重新分配给log4j--System.setOut(newLog4jStream())最好的问候 最佳答案 ApacheCommonsExec库包含有用的类LogOutputStream,您可以将其用于此确切目的:LogOutputStreamlosStdOut=newLogOutputStream(){@Overrideprotec
我需要从Apex代码更改Salesforce任务的创建日期。我该怎么做呢?我通过Internet浏览,发现这是可能的。1。在权限集中启用审计字段。2.可以使用DataLoader或API更改创建的DATE(在数据导入期间)3。可以修改Apex测试类中的日期(注意:我们不能从测试类中修改实际数据)但是我想要的是我需要从Apex代码更改(请与测试类混淆)。有人可以给我一个快速解决方案吗?看答案您无法更改记录的创建日期,这不是一个可编辑的字段。审核字段perm允许您在插入中设置CreateDate,但不能更新。
我在我的controller中实例化了一个名为myDate的java.util.Date对象,并将它传递给我的JSP,在那里我有一个JodaTime在页面顶部用这个配置的JSP标记:当然还有必要的Maven依赖项通过POM文件添加到项目中。但是,当我尝试像这样从JSP访问myDate时:我收到这个错误:javax.servlet.jsp.JspException:valueattributeofformattagmustbeaReadableInstantorReadablePartial,was:java.util.Date引用documentationfortheJodaTimeJ