Отключите ведение журнала PDFBox с помощью Springboot org.apache.commons.logging - PullRequest
0 голосов
/ 01 октября 2019

Я не могу найти способ остановить предупреждения от PDFBox, который я использую в загрузочном приложении psring. Например:

2019-10-01 16:53:51.021  WARN 24564 --- [nio-8443-exec-2] o.a.pdfbox.pdmodel.font.PDType0Font      : No Unicode mapping for CID+4 (4) in font Calibri-Bold

2019-10-01 16:53:51.022  WARN 24564 --- [nio-8443-exec-2] o.a.pdfbox.pdmodel.font.PDCIDFontType2   : Failed to find a character mapping for 4 in Calibri-Bold

2019-10-01 16:53:51.022  WARN 24564 --- [nio-8443-exec-2] o.a.pdfbox.pdmodel.font.PDCIDFontType2   : Failed to find a character mapping for 4 in Calibri-Bold

Я пытался: В файле приложения:

static {
  System.setProperty("org.apache.commons.logging.Log", "org.apache.commons.logging.impl.NoOpLog");
  java.util.logging.Logger.getLogger("org.apache.pdfbox").setLevel(java.util.logging.Level.OFF);

  String[] loggers = {
    "org.apache.pdfbox.util.PDFStreamEngine",
    "org.apache.pdfbox.pdmodel.font.PDSimpleFont",
    "org.apache.pdfbox.pdmodel.font.PDFont",
    "org.apache.pdfbox.pdmodel.font.FontManager",
    "org.apache.pdfbox.pdfparser.PDFObjectStreamParser",
    "o.a.pdfbox.pdmodel.font.PDCIDFontType2",
    "org.apache.pdfbox.pdmodel.font.PDCIDFontType2",
    "o.a.pdfbox.pdmodel.font.PDType0Font",
    "org.apache.pdfbox.pdmodel.font.PDType0Font",
    "org.apache.pdfbox.pdmodel.font.PDType1Font"
  };
  for (String logger: loggers) {
    org.apache.log4j.Logger logpdfengine = org.apache.log4j.Logger
      .getLogger(logger);
    logpdfengine.setLevel(org.apache.log4j.Level.OFF);
  }

}

Как параметр при запуске jar:

-Dorg.apache.commons.logging.Log=org.apache.commons.logging.impl.NoOpLog
-Dorg.slf4j.simpleLogger.defaultLogLevel=off

В коде PDFBox,Журнал настраивается с помощью:

(import org.apache.commons.logging.LogFactory;)

private static final Log LOG = LogFactory.getLog(PDCIDFontType0.class);

LOG.warn("Found PFB but expected embedded CFF font " + fd.getFontName());

Я потратил много времени, пробуя много вещей, и просматривал ответы на похожие вопросы в SO, но нигде не получил.

Ответы [ 3 ]

1 голос
/ 03 октября 2019

Это файл конфигурации, который я в итоге использовал. Я не включал в журналирование определенных зависимостей и не добавлял никаких исключений в зависимость pdfbox, просто добавил этот файл в папку, содержащую файл application.properties.

Имя файла: logback-spring.xml

Регистратор переполнения был скопирован с как изменить уровни журнала сторонней библиотеки в java

<property name="LOGS" value="./logs" />

<appender name="Console"
    class="ch.qos.logback.core.ConsoleAppender">
    <layout class="ch.qos.logback.classic.PatternLayout">
        <Pattern>
            %black(%d{ISO8601}) %highlight(%-5level) [%blue(%t)] %yellow(%C{1.}): %msg%n%throwable
        </Pattern>
    </layout>
</appender>

<appender name="RollingFile"
    class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${LOGS}/spring-boot-logger.log</file>
    <encoder
        class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
        <Pattern>%d %p %C{1.} [%t] %m%n</Pattern>
    </encoder>

    <rollingPolicy
        class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <!-- rollover daily and when the file reaches 10 MegaBytes -->
        <fileNamePattern>${LOGS}/archived/spring-boot-logger-%d{yyyy-MM-dd}.%i.log
        </fileNamePattern>
        <timeBasedFileNamingAndTriggeringPolicy
            class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
            <maxFileSize>10MB</maxFileSize>
        </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
</appender>

<!-- LOG everything at INFO level -->
<root level="info">
    <appender-ref ref="RollingFile" />
    <appender-ref ref="Console" />
</root>

<!-- LOG "com.baeldung*" at TRACE level -->
<logger name="org.apache" level="ERROR" additivity="false">
    <appender-ref ref="RollingFile" />
    <appender-ref ref="Console" />
</logger>

<logger name="flooding logger" level="ERROR" additivity="false">
  <appender-ref ref="Console"/>

0 голосов
/ 04 октября 2019

Я думаю, это также должно работать для log4j2. Я использую этот простой способ отключения журналов из определенных библиотек в приложениях SpringBoot . Вам просто нужно добавить его в файл log4j2.xml.

<Loggers>  
    <Root>
        ****** here is some AppenderRef *******
    </Root>      
    <Logger name="o.a.pdfbox" level="off"/>
    or 
    <Logger name="org.apache.pdfbox" level="off"/> 

</Loggers>
0 голосов
/ 01 октября 2019

Вот что я использовал в "старом" файле log4j log4j.properties (вам нужно перейти на log4j2):

log4j.logger.org.springframework=WARN
log4j.logger.org.apache.pdfbox.pdmodel.font.PDCIDFontType2=FATAL

В "новом" log4j2.xml у меня есть это (appendersназваны STDOUT и A1):

<?xml version="1.0" encoding="UTF-8"?>
<!-- https://logging.apache.org/log4j/2.x/manual/configuration.html 
     https://logging.apache.org/log4j/2.x/manual/appenders.html
-->
<Configuration>
    <Appenders>
        ....
        ....
    </Appenders>
    <Loggers>
        <Logger name="org.springframework" level="warn" additivity="false">
            <AppenderRef ref="STDOUT"/>
            <AppenderRef ref="A1"/>
        </Logger>
        <Logger name="org.apache.pdfbox.pdmodel.font.PDCIDFontType2" level="fatal" additivity="false">
            <AppenderRef ref="STDOUT"/>
            <AppenderRef ref="A1"/>
        </Logger>
        <Root level="info">
            <AppenderRef ref="STDOUT"/>
            <AppenderRef ref="A1"/>
        </Root>
    </Loggers>
</Configuration>
...