2013-02-11 3 views
0

Я пытаюсь отправить ошибки моего проекта GWT с log4j, но у меня проблема. Это то, что я добавил в файл log4j.xml:Log4j - STMPAppender NoSuchProviderException stmp

<appender name="EMAIL" class="org.apache.log4j.net.SMTPAppender"> 
<param name="BufferSize" value="512" /> 
<param name="SMTPHost" value="localhost" /> 
<param name="From" value="[email protected]" /> 
<param name="To" value="[email protected]" /> 
<param name="Subject" value="[SMTPAppender] Application message" /> 
<layout class="org.apache.log4j.PatternLayout"> 
    <param name="ConversionPattern" value="%p %d (%c{1}) %m%n" /> 
</layout> 
<filter class="org.apache.log4j.varia.LevelRangeFilter"> 
    <param name="LevelMin" value="ERROR" /> 
    <param name="LevelMax" value="FATAL" /> 
</filter> 
</appender> 

<root> 
<level value="WARN" /> 
<appender-ref ref="EMAIL" /> 
</root> 

Простой, но это дает мне следующую ошибку при попытке отправить сообщение электронной почты?

log4j:ERROR Error occured while sending e-mail notification. 
javax.mail.NoSuchProviderException: smtp 
at javax.mail.Session.getService(Session.java:806) 
at javax.mail.Session.getTransport(Session.java:728) 
at javax.mail.Session.getTransport(Session.java:668) 
at javax.mail.Session.getTransport(Session.java:648) 
at javax.mail.Session.getTransport(Session.java:705) 
at javax.mail.Transport.send0(Transport.java:192) 
at javax.mail.Transport.send(Transport.java:124) 
at org.apache.log4j.net.SMTPAppender.sendBuffer(SMTPAppender.java:330) 
at org.apache.log4j.net.SMTPAppender.append(SMTPAppender.java:215) 
at org.apache.log4j.AppenderSkeleton.doAppend(AppenderSkeleton.java:251) 
at org.apache.log4j.helpers.AppenderAttachableImpl.appendLoopOnAppenders(AppenderAttachableImpl.java:66) 
at org.apache.log4j.Category.callAppenders(Category.java:206) 
at org.apache.log4j.Category.forcedLog(Category.java:391) 
at org.apache.log4j.Category.error(Category.java:305) 
at pt.keep.vault.web.server.WebServiceImpl.login(WebServiceImpl.java:1257) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
at java.lang.reflect.Method.invoke(Method.java:597) 
at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:561) 
at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:208) 
at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:248) 
at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java:62) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:637) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487) 
at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362) 
at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) 
at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181) 
at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729) 
at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405) 
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) 
at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49) 
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) 
at org.mortbay.jetty.Server.handle(Server.java:324) 
at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505) 
at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:843) 
at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:647) 
at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211) 
at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380) 
at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395) 
at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488) 

Я уже добавил в свой проект активацию-1.1.jar и mail.jar (1.4.6 API). Что может быть неправильным?

Заранее спасибо.

+0

вы уверены, что ваша баночка находитесь в вашей войне? – twillouer

+0

Файлы .jar находятся в состоянии войны/WEB-INF/lib/... Что может быть неправильно? –

+0

Да, я думаю, у вас есть тезисы на другом пути, и причал возьмет их первым. Попытайтесь найти их., Especialy mail.jar (mail-1.3 ..... jar in example) – twillouer

ответ

0

Пробуйте эту конфигурацию - она ​​работает для меня, и она использует gmail как smtp-сервер, который может быть хорошим вариантом для вас как в среде разработки, так и в производственной среде. Я использую log4j версию: 1.2.16 и апач-log4j-дополнение версия 1.0 (эта дополнительная Lib является только если необходимой вы используете: FilterBasedTriggeringPolicy)

<appender name="emailApp" class="org.apache.log4j.net.SMTPAppender"> 
    <param name="SMTPProtocol" value="smtps" /> 
    <param name="SMTPHost" value="smtp.gmail.com" /> 
    <param name="SMTPPort" value="465" /> 
    <param name="SMTPUsername" value="your.gmail.username" /> 
    <param name="SMTPPassword" value="xxxxx" /> 
    <param name="From" value="[email protected]" /> 
    <param name="To" value="[email protected]" /> 
    <param name="Subject" value="Logging from my application" /> 
    <param name="BufferSize" value="1" /> 
    <triggeringPolicy class="org.apache.log4j.rolling.FilterBasedTriggeringPolicy"> 
     <filter class="org.apache.log4j.varia.LevelRangeFilter"> 
      <param name="LevelMin" value="WARN"/> 
      <param name="LevelMax" value="FATAL"/> 
     </filter> 
    </triggeringPolicy> 
    <layout class="org.apache.log4j.PatternLayout"> 
     <param name="ConversionPattern" value="%d{dd-MM-yyyy HH:mm:ss:SSS} %-4r %-5p %c %x - %m%n"/> 
    </layout> 
</appender> 
+0

Stills дает ту же ошибку. Файлы .jar находятся в состоянии войны/WEB-INF/lib/... Что может быть неправильным? –

+0

Да, банки должны быть в каталоге WEB-INF/lib –

+0

После развертывания в tomcat он работает. С средой разработки GWT она не работает, но это не проблема. Проблема в том, что я не могу поместить ее в SMTPS, потому что она не переконвертирует теги STMPProtocol и SMTPHost. –

Смежные вопросы