Я уже давно использую log4j и обычно использую его в верхней части log4j.xml (вероятно, как и многие другие, и, по мнению Google, это способ сделать это ):
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
Очевидно, что это работает, однако Eclipse не предоставляет контекстно-зависимую справку для написания XML и всего. Кроме того, он всегда показывает предупреждение о том, что не находит log4j.dtd
. Теперь мне интересно, как это исправить.
Я попробовал несколько вещей, и эти работы:
<!DOCTYPE log4j:configuration SYSTEM "jar:file:/path/.m2/repository/log4j/log4j/1.2.14/log4j-1.2.14.jar!/org/apache/log4j/xml/log4j.dtd">
<!DOCTYPE log4j:configuration SYSTEM "http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/xml/doc-files/log4j.dtd">
Как вы можете видеть сверху, мы используем Maven. Поэтому я попробовал это, но это не удалось:
<!DOCTYPE log4j:configuration SYSTEM "jar:file:${M2_REPO}/log4j/log4j/1.2.14/log4j-1.2.14.jar!/org/apache/log4j/xml/log4j.dtd">
Eclipse обычно знает, как обращаться с переменными classpath, но почему это не работает? Я знаю, что ссылка не будет работать во время выполнения, но и простой log4j.dtd
(если я не ошибаюсь), так что это не должно быть проблемой.
Может кто-нибудь пролить свет на это?