Вход SMTPAppender не отправляет электронную почту
Я пытаюсь использовать Logback для входа в приложение Java. Я считаю, что я правильно настроил, но когда регистрируется ошибка
ИНФОРМАЦИЯ в ch.qos.logback.classic.net.SMTPAppender[EMAIL] - о том, чтобы отправить SMTP-сообщение "Главная проверка" на [XXXX@optonline.net]
выводится на консоль, больше ничего не печатается после этого, и электронное письмо никогда не принимается. Если я ввожу неверный хост smtp или имя пользователя / пароль в конфиге, то при попытке отправки немедленно произойдет сбой, поэтому он устанавливает соединение.
Мое ПОМ:
<repositories>
<repository>
<id>Java.Net</id>
<url>http://download.java.net/maven/2/</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>javax.activation</groupId>
<artifactId>activation</artifactId>
<version>1.1.1</version>
</dependency>
<dependency>
<groupId>javax.mail</groupId>
<artifactId>mail</artifactId>
<version>1.4.7</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.1.1</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.1.1</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.6</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>1.7.6</version>
</dependency>
</dependencies>
logback.xml
<configuration>
<!-- dump status message on the console as they arrive -->
<statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener" />
<appender name="EMAIL" class="ch.qos.logback.classic.net.SMTPAppender">
<smtpHost>mail.optonline.net</smtpHost>
<username>xxxxx</username>
<password>xxxxxx</password>
<smtpPort>587</smtpPort>
<to>xxxxx@optonline.net</to>
<from>xxxxx@optonline.net</from>
<subject>Testing %logger
{20}
- %m</subject>
<layout class="ch.qos.logback.classic.PatternLayout">
<pattern>%d
{HH:mm:ss.SSS}
[%thread] %-5level %logger
{1}
-%msg%n
</pattern>
</layout>
</appender>
<root level="info">
<appender-ref ref="EMAIL" />
</root>
</configuration>
Консоль
10:45:44,596 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Could NOT find resource [logback.groovy]
10:45:44,596 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Could NOT find resource [logback-test.xml]
10:45:44,596 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Found resource [logback.xml] at [file:/C:/Users/xxxxx/workspace/logback-test/target/classes/logback.xml]
10:45:44,650 |-INFO in ch.qos.logback.classic.joran.action.ConfigurationAction - debug attribute not set
10:45:44,658 |-INFO in ch.qos.logback.core.joran.action.StatusListenerAction - Added status listener of type [ch.qos.logback.core.status.OnConsoleStatusListener]
10:45:44,673 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - About to instantiate appender of type [ch.qos.logback.classic.net.SMTPAppender]
10:45:44,688 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - Naming appender as [EMAIL]
10:45:44,765 |-INFO in ch.qos.logback.classic.joran.action.RootLoggerAction - Setting level of ROOT logger to INFO
10:45:44,765 |-INFO in ch.qos.logback.core.joran.action.AppenderRefAction - Attaching appender named [EMAIL] to Logger[ROOT]
10:45:44,766 |-INFO in ch.qos.logback.classic.joran.action.ConfigurationAction - End of configuration.
10:45:44,767 |-INFO in ch.qos.logback.classic.joran.JoranConfigurator@ddc652f - Registering current configuration as safe fallback point
10:45:44,774 |-INFO in ch.qos.logback.classic.net.SMTPAppender[EMAIL] - SMTPAppender [EMAIL] is tracking [1] buffers
exiting
10:45:44,791 |-INFO in ch.qos.logback.classic.net.SMTPAppender[EMAIL] - About to send out SMTP message "Testing Main" to [xxxxx@optonline.net]
10:45:44,791 |-INFO in ch.qos.logback.classic.net.SMTPAppender[EMAIL] - About to send out SMTP message "Testing Main" to [xxxxx@optonline.net]
Это код, который запускается для создания моих тестовых ошибок
logger.error("Entering app");
logger.error("exiting app");
System.out.println("exiting");
Любая помощь в устранении этой проблемы будет принята с благодарностью
3 ответа
Кажется, это была проблема с SMTP-сервером, который я использовал. Я настроил Papercut как локальный SMTP-сервер и вижу, как он получает сообщения
Я тоже столкнулся с этой проблемой и нашел решение. Для запуска вышеуказанного кода необходимо внести некоторые изменения:
1. Add `<STARTTLS>true</STARTTLS>` in your configuration
2. Add <asynchronousSending>false</asynchronousSending>
Если вы используете Gmail для отправки писем, то у меня сработали следующие конфигурации логбэка.
<springProperty scope="context" name="smtpHost" source="spring.mail.host" />
<springProperty scope="context" name="smtpPort" source="spring.mail.port" />
<springProperty scope="context" name="username" source="spring.mail.username" />
<springProperty scope="context" name="password" source="spring.mail.password" />
<appender name="EMAIL" class="ch.qos.logback.classic.net.SMTPAppender">
<smtpHost>${smtpHost}</smtpHost>
<smtpPort>${smtpPort}</smtpPort>
<SSL>true</SSL>
<username>${username}</username>
<password>${password}</password>
<to>${username}</to>
<from>${username}</from>
<subject>Error From ERP: %logger{20} - %m</subject>
<layout class="ch.qos.logback.classic.html.HTMLLayout"/>
<cyclicBufferTracker class="ch.qos.logback.core.spi.CyclicBufferTracker">
<!-- only 5 log entries on email -->
<bufferSize>5</bufferSize>
</cyclicBufferTracker>
</appender>
Хотя мои конфигурации существуют в файле application.yaml, который можно увидеть, я пытаюсь получить их оттуда. В моем случае для порта smtp установлено значение 465.