我有一些想要禁用的警告。他们来自
org.eclipse.lyo.oslc4j.provider.jena.JenaModelHelper
班级。所以我使用 log4j 并在运行时调用
Logger.getLogger("org.eclipse.lyo.oslc4j.provider.jena.JenaModelHelper").setLevel(Level.OFF);
但什么也没发生。
为此,我调试了有问题的代码,前 3 次显示警告,但在第 4 次时,级别发生了更改。
我在请求时(在构造函数中)更改了日志级别,因此我认为当考虑到运行时应用的规则时,log4j 中有一些刷新机制。
有没有办法立即触发这种情况?
编辑:
警告消息是:
WARNING: Property http://localhost:8080/dwa/rm/urn:rational::1-55422447386d3378-M-00000200/types/attrDef-7 could not be parsed as datatype http://www.w3.org/2001/XMLSchema#dateTime
com.hp.hpl.jena.datatypes.DatatypeFormatException: Lexical form '2015-06-10' is not a legal instance of Datatype[http://www.w3.org/2001/XMLSchema#dateTime -> class com.hp.hpl.jena.datatypes.xsd.XSDDateTime] Lexical form '2015-06-10' is not a legal instance of Datatype[http://www.w3.org/2001/XMLSchema#dateTime -> class com.hp.hpl.jena.datatypes.xsd.XSDDateTime] during parse -org.apache.xerces.impl.dv.InvalidDatatypeValueException: cvc-datatype-valid.1.2.1: '2015-06-10' is not a valid value for 'dateTime'.
at com.hp.hpl.jena.graph.impl.LiteralLabelImpl.getValue(LiteralLabelImpl.java:339)
at com.hp.hpl.jena.graph.Node_Literal.getLiteralValue(Node_Literal.java:39)
at com.hp.hpl.jena.rdf.model.impl.LiteralImpl.getValue(LiteralImpl.java:98)
您可以在配置文件(log4j.properties)中禁用日志记录,因此这将在启动时设置:
log4j.logger.org.eclipse.lyo.oslc4j.provider.jena.JenaModelHelper=错误
您发布的警告看起来很像 Java Util Logging 消息,这些消息不会由 Log4J 控制,因为它是一个不同的框架。您可以在虚拟机“logging.properties”文件中禁用该消息:
org.eclipse.lyo.oslc4j.provider.jena.JenaModelHelper.level=SEVERE
或者您可以添加SLF4J http://www.slf4j.org/legacy.html到您的项目以将遗留框架消息重定向到 Log4J。要做到这一点,把slf4j-api.jar http://mvnrepository.com/artifact/org.slf4j/slf4j-api, jcl-over-slf4j.jar http://mvnrepository.com/artifact/org.slf4j/jcl-over-slf4j, 七月至 slf4j.jar http://mvnrepository.com/artifact/org.slf4j/jul-to-slf4j and slf4j-log4j12.jar http://mvnrepository.com/artifact/org.slf4j/slf4j-log4j12在你的类路径中。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)