从应用程序发送电子邮件时的javax.ejb.EJBException
我正在使用GlassFish 5.1、Java 1.8、JavaMail、JavaFaces 2.2开发一个JavaEE应用程序,在该应用程序中,我需要在调用方法时发送电子邮件,但当我从服务器运行它时,会显示以下错误:从应用程序发送电子邮件时的javax.ejb.EJBException,java,jakarta-mail,glassfish-5,Java,Jakarta Mail,Glassfish 5,我正在使用GlassFish 5.1、Java 1.8、JavaMail、JavaFaces 2.2开发一个JavaEE应用程序,在该应用程序中,我需要在调用方法时发送电子邮件,但当我从服务器运行它时,会显示以下错误: Warning: javax.ejb.EJBException at com.sun.ejb.containers.EJBContainerTransactionManager.processSystemException(EJBContainerTransactionM
Warning: javax.ejb.EJBException
at com.sun.ejb.containers.EJBContainerTransactionManager.processSystemException(EJBContainerTransactionManager.java:728)
at com.sun.ejb.containers.EJBContainerTransactionManager.completeNewTx(EJBContainerTransactionManager.java:678)
at com.sun.ejb.containers.EJBContainerTransactionManager.postInvokeTx(EJBContainerTransactionManager.java:483)
at com.sun.ejb.containers.BaseContainer.postInvokeTx(BaseContainer.java:4576)
at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:2084)
at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:2054)
at com.sun.ejb.containers.EJBObjectInvocationHandler.invoke(EJBObjectInvocationHandler.java:188)
at com.sun.ejb.containers.EJBObjectInvocationHandlerDelegate.invoke(EJBObjectInvocationHandlerDelegate.java:55)
at com.sun.proxy.$Proxy268.preInscripcion(Unknown Source)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at com.sun.corba.ee.impl.presentation.rmi.ReflectiveTie.dispatchToMethod(ReflectiveTie.java:113)
at com.sun.corba.ee.impl.presentation.rmi.ReflectiveTie._invoke(ReflectiveTie.java:143)
at com.sun.corba.ee.impl.protocol.ServerRequestDispatcherImpl.dispatchToServant(ServerRequestDispatcherImpl.java:490)
at com.sun.corba.ee.impl.protocol.ServerRequestDispatcherImpl.dispatch(ServerRequestDispatcherImpl.java:161)
at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleRequestRequest(MessageMediatorImpl.java:1520)
at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleRequest(MessageMediatorImpl.java:1396)
at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleInput(MessageMediatorImpl.java:901)
at com.sun.corba.ee.impl.protocol.giopmsgheaders.RequestMessage_1_2.callback(RequestMessage_1_2.java:183)
at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleRequest(MessageMediatorImpl.java:665)
at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.dispatch(MessageMediatorImpl.java:467)
at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.doWork(MessageMediatorImpl.java:2193)
at com.sun.corba.ee.impl.threadpool.ThreadPoolImpl$WorkerThread.performWork(ThreadPoolImpl.java:467)
at com.sun.corba.ee.impl.threadpool.ThreadPoolImpl$WorkerThread.run(ThreadPoolImpl.java:510)
Caused by: java.lang.NoClassDefFoundError: sun/security/ssl/HandshakeStateManager
at sun.security.ssl.Handshaker.init(Handshaker.java:282)
at sun.security.ssl.Handshaker.<init>(Handshaker.java:242)
at sun.security.ssl.ClientHandshaker.<init>(ClientHandshaker.java:160)
at sun.security.ssl.SSLSocketImpl.initHandshaker(SSLSocketImpl.java:1329)
at sun.security.ssl.SSLSocketImpl.doneConnect(SSLSocketImpl.java:690)
at sun.security.ssl.SSLSocketImpl.<init>(SSLSocketImpl.java:569)
at sun.security.ssl.SSLSocketFactoryImpl.createSocket(SSLSocketFactoryImpl.java:110)
at com.sun.mail.util.SocketFetcher.startTLS(SocketFetcher.java:528)
at com.sun.mail.smtp.SMTPTransport.startTLS(SMTPTransport.java:2126)
at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:728)
at javax.mail.Service.connect(Service.java:342)
at javax.mail.Service.connect(Service.java:222)
at javax.mail.Service.connect(Service.java:243)
at com.prueba.dao.UsuarioDAO.enviarEmail(UsuarioDAO.java:80)
at com.prueba.model.Estudiante.agregarUsuario(Estudiante.java:19)
at com.prueba.sessionbeans.EstudianteBean.preInscripcion(EstudianteBean.java:12)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.glassfish.ejb.security.application.EJBSecurityManager.runMethod(EJBSecurityManager.java:1057)
at org.glassfish.ejb.security.application.EJBSecurityManager.invoke(EJBSecurityManager.java:1129)
at com.sun.ejb.containers.BaseContainer.invokeBeanMethod(BaseContainer.java:4796)
at com.sun.ejb.EjbInvocation.invokeBeanMethod(EjbInvocation.java:632)
at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:800)
at com.sun.ejb.EjbInvocation.proceed(EjbInvocation.java:584)
at org.jboss.weld.module.ejb.AbstractEJBRequestScopeActivationInterceptor.aroundInvoke(AbstractEJBRequestScopeActivationInterceptor.java:81)
at org.jboss.weld.module.ejb.SessionBeanInterceptor.aroundInvoke(SessionBeanInterceptor.java:52)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at com.sun.ejb.containers.interceptors.AroundInvokeInterceptor.intercept(InterceptorManager.java:859)
at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:799)
at com.sun.ejb.EjbInvocation.proceed(EjbInvocation.java:584)
at com.sun.ejb.containers.interceptors.SystemInterceptorProxy.doCall(SystemInterceptorProxy.java:139)
at com.sun.ejb.containers.interceptors.SystemInterceptorProxy.aroundInvoke(SystemInterceptorProxy.java:116)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at com.sun.ejb.containers.interceptors.AroundInvokeInterceptor.intercept(InterceptorManager.java:859)
at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:799)
at com.sun.ejb.containers.interceptors.InterceptorManager.intercept(InterceptorManager.java:345)
at com.sun.ejb.containers.BaseContainer.__intercept(BaseContainer.java:4768)
at com.sun.ejb.containers.BaseContainer.intercept(BaseContainer.java:4756)
at com.sun.ejb.containers.EJBObjectInvocationHandler.invoke(EJBObjectInvocationHandler.java:181)
... 19 more
当我执行代码时,错误标记在下面的行transport.connect(mailSender,passwordSender)代码>
我一直在尝试使用不同版本的JavaMail(1.4.5-1.6.2),我使用的是JDK8u111并将其更新为JDK8u261,但什么都没有,我还尝试将glizzly npn bootstrap.JAR的JAR从1.5版更改为1.9版(如下所述),但它仍然给我相同的错误。我不知道哪里出了问题,也不知道如何解决。我无法找到GlassFish 5.1服务器中出现的问题的解决方案,但在Payara 5.2服务器上运行应用程序时,没有出现错误,一切都很好,但是,我决定将应用程序留给JDK8u261,以避免可能出现的版本兼容性问题。
我使用的Payara的下载链接是。请将您问题的标题翻译成英语。我认为这可能与您的问题相同。Glassfish与您正在使用的Java 8的特定版本之间存在不兼容。我尝试更改JDK版本,但什么都没有。您应该将所有相关组件版本的完整和精确细节添加到票据中;i、 e.JDK、Glassfish和JavaMail的完整版本号。我看你已经为JavaMail做了这件事。(说你改变了它并不能告诉我们它以前是什么或现在是什么!)这可能会帮助其他人为你研究问题的原因。将信息添加到问题中,而不是作为评论。
try{
Properties props=new Properties();
props.setProperty("mail.smtp.host", "smtp.gmail.com");
props.setProperty("mail.smtp.starttls.enable", "true");
props.setProperty("mail.smtp.port", "587");
props.setProperty("mail.smtp.aunth", "true");
Session session=Session.getDefaultInstance(props);
MimeMessage message=new MimeMessage(session);
message.setFrom(new InternetAddress(mailSender));
message.addRecipient(Message.RecipientType.TO, new InternetAddress(mailReceptor));
message.setSubject(asunto);
message.setText(mensaje);
Transport transport=session.getTransport("smtp");
transport.connect(mailSender, passwordSender);
transport.sendMessage(message, message.getRecipients(Message.RecipientType.TO));
transport.close();
return true;
}
catch(AddressException e){
e.printStackTrace();
}
catch(MessagingException e){
e.printStackTrace();
}