- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先我使用glassfish4
服务器。当我尝试从网络测试应用程序发送电子邮件时,我收到一个异常,通常显示:
javax.mail.MessagingException: Could not connect to SMTP host: mail.host.com, port: 465, response: -1
(我还遇到了另一个异常,但我不记得了),但是从我的 SE 应用程序中,它每次都能正确发送电子邮件。另外,我的同事在他的计算机上有与我相同的代码,并且该代码有效。我还尝试使用 smtp.gmail.com 发送电子邮件,它的工作方式非常出色,但是当我尝试使用我们的私有(private)服务器时,它不起作用。
这是我的网络应用程序的代码:
@WebServlet("/email")
public class Email extends HttpServlet{
private static final String SUBJECT = "TEST";
private static final String CONTENT = "<h1>HI</h1>"
+ "<header style='width: 100%; height=20vh; background: #ffdd1a; color: #383e72;'>"
+ "<h1>TEST</h1>"
+ "<h2>KTHXBYE</h2>"
+ "</header>";
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String name = req.getParameter("name"),
eMail = req.getParameter("eMail"),
server = req.getParameter("server"),
port = req.getParameter("port"),
encryption = req.getParameter("encryption"),
mailTo = req.getParameter("mailTo");
final String username = req.getParameter("username"),
pass = req.getParameter("pass");
resp.setCharacterEncoding("UTF-8");
Session session;
// setup acc props
Properties props = System.getProperties();
props.put("mail.smtp.host", server);
props.put("mail.smtp.port", port);
props.put("mail.smtp.auth", "true");
props.put("mail.transport.protocol", "smtp");
switch (povezava) {
case "SSL":
props.put("mail.smtp.socketFactory.port", "port");
props.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
break;
case "TLS":
props.put("mail.smtp.starttls.enable", "true");
break;
case "NONE":
props.put("mail.smtp.ssl.enable", "false");
props.put("mail.smtp.starttls.enable", "false");
props.put("mail.smtp.ssl.trust", server);
break;
default:
resp.getWriter().print("ERROR");
return;
}
Authenticator auth = new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, pass);
}
};
// create msg
session = Session.getDefaultInstance(props, auth);
session.setDebug(true);
MimeMessage message = new MimeMessage(session);
try {
try {
message.setFrom(new InternetAddress(eMail, name));
message.setSubject(SUBJECT);
MimeMultipart multipart = new MimeMultipart("related");
BodyPart bodyPart = new MimeBodyPart();
bodyPart.setContent(CONTENT, "text/html; charset=utf-8");
multipart.addBodyPart(bodyPart);
message.setContent(multipart);
// send msg
message.setRecipient(Message.RecipientType.TO, new InternetAddress(mailTo));
// Transport transport = session.getTransport("smtp");
// transport.connect(server, username, pass);
// transport.sendMessage(message, message.getAllRecipients());
Transport.send(message);
resp.getWriter().print("Mail was send successfully");
return;
} catch (MessagingException ex) {
Logger.getLogger(Email.class.getName()).log(Level.SEVERE, null, ex);
}
} catch (UnsupportedEncodingException ex) {
Logger.getLogger(Email.class.getName()).log(Level.SEVERE, null, ex);
}
resp.getWriter().print("Sending mail failed");
}
}
来自上层代码的堆栈跟踪:
javax.mail.MessagingException: Could not connect to SMTP host: mail.host.com, port: 465, response: -1
at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:2042)
at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:697)
at javax.mail.Service.connect(Service.java:386)
at javax.mail.Service.connect(Service.java:245)
at javax.mail.Service.connect(Service.java:194)
at javax.mail.Transport.send0(Transport.java:253)
at javax.mail.Transport.send(Transport.java:124)
at com.zarja.testmail.Email.doPost(Email.java:113)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:707)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:318)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:160)
at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:734)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:673)
at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:99)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:174)
at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:416)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:283)
at com.sun.enterprise.v3.services.impl.ContainerMapper$HttpHandlerCallable.call(ContainerMapper.java:459)
at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:167)
at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:206)
at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:180)
at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:235)
at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:283)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:200)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:132)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:111)
at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)
at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:536)
at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:112)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:117)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:56)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:137)
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:591)
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:571)
at java.lang.Thread.run(Thread.java:748)
现在是我的 SE 应用程序代码:
public static void main(String[] args) {
System.out.println(sendMyMail());
}
public static String sendMyMail() {
try {
String from = "mailaddress"; // not actual mail
String pass = "password";
Authenticator auth = new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(from, pass);
}
};
Session session;
//setup account properties
Properties props = System.getProperties();
props.put("mail.smtp.host", "mail.host.com");
props.put("mail.smtp.socketFactory.port", "465");
props.put("mail.smtp.socketFactory.class",
"javax.net.ssl.SSLSocketFactory");
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.port", "465");
session = Session.getDefaultInstance(props, auth);
session.setDebug(true);
MimeMessage message = new MimeMessage(session);
message.setFrom(new InternetAddress(from, "TEST"));
message.setSubject(SUBJECT);
MimeMultipart multipart = new MimeMultipart("related");
BodyPart messageBodyPart = new MimeBodyPart();
messageBodyPart.setContent(CONTENT, "text/html; charset=utf-8");
multipart.addBodyPart(messageBodyPart);
message.setContent(multipart);
//send message
try {
message.setRecipient(Message.RecipientType.TO, new InternetAddress("host@gmail.com"));
// Transport transport = session.getTransport("smtp");
// transport.connect("mail.host.com", from, pass);
// transport.sendMessage(message, message.get
AllRecipients());
Transport .send(message);
return "SENT";
} catch (Exception e) {
e.printStackTrace();
}
} catch (Exception e) {
e.printStackTrace();
}
return "FAILED";
}
感谢您提前提供的帮助!
编辑(代码实际上应该是什么样子):
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String name = req.getParameter("name"),
eMail = req.getParameter("eMail"),
server = req.getParameter("server"),
port = req.getParameter("port"),
encryption = req.getParameter("encryption"),
mailTo = req.getParameter("mailTo");
final String username = req.getParameter("username"),
pass = req.getParameter("pass");
resp.setCharacterEncoding("UTF-8");
Session session;
// setup acc props
Properties props = System.getProperties();
props.put("mail.smtp.host", server);
props.put("mail.smtp.port", port);
props.put("mail.smtp.auth", "true");
props.put("mail.transport.protocol", "imap");
switch (enryption) {
case "SSL":
props.put("mail.smtp.ssl.enable", "true");
break;
case "TLS":
props.put("mail.smtp.starttls.enable", "true");
break;
case "NONE":
props.put("mail.smtp.ssl.enable", "false");
props.put("mail.smtp.starttls.enable", "false");
props.put("mail.smtp.ssl.trust", server);
break;
default:
resp.getWriter().print("ERROR");
return;
}
// create msg
session = Session.getInstance(props);
session.setDebug(true);
MimeMessage message = new MimeMessage(session);
try {
try {
message.setFrom(new InternetAddress(eMail, name));
message.setSubject(SUBJECT);
MimeMultipart multipart = new MimeMultipart("related");
BodyPart bodyPart = new MimeBodyPart();
bodyPart.setContent(CONTENT, "text/html; charset=utf-8");
multipart.addBodyPart(bodyPart);
message.setContent(multipart);
// send msg
message.setRecipient(Message.RecipientType.TO, new InternetAddress(mailTp));
Transport transport = session.getTransport("imap");
transport.connect(streznikPoste, uporabniskoIme, geslo);
Transport.send(message);
resp.getWriter().print("Mail was send successfully");
return;
} catch (MessagingException ex) {
Logger.getLogger(Email.class.getName()).log(Level.SEVERE, null, ex);
}
} catch (UnsupportedEncodingException ex) {
Logger.getLogger(Email.class.getName()).log(Level.SEVERE, null, ex);
}
resp.getWriter().print("Sending mail failed");
}
编辑修复(这似乎有效):
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String name = req.getParameter("name"),
eMail = req.getParameter("eMail"),
server = req.getParameter("server"),
port = req.getParameter("port"),
encryption = req.getParameter("encryption"),
mailTo = req.getParameter("mailTo");
final String username = req.getParameter("username"),
pass = req.getParameter("pass");
resp.setCharacterEncoding("UTF-8");
Session session;
// setup acc props
Properties props = System.getProperties();
props.put("mail.smtp.host", server);
props.put("mail.smtp.port", port);
props.put("mail.smtp.auth", "true");
props.put("mail.transport.protocol", "smtp");
props.put("mail.smtp.ssl.trust", server);
switch (encryption) {
case "SSL":
props.put("mail.smtp.ssl.enable", "true");
break;
case "TLS":
props.put("mail.smtp.starttls.enable", "true");
break;
case "NONE":
props.put("mail.smtp.ssl.enable", "false");
props.put("mail.smtp.starttls.enable", "false");
props.put("mail.smtp.ssl.trust", server);
break;
default:
resp.getWriter().print("ERROR");
return;
}
// create msg
session = Session.getInstance(props);
session.setDebug(true);
MimeMessage message = new MimeMessage(session);
try {
try {
message.setFrom(new InternetAddress(eMail, name));
message.setSubject(SUBJECT);
MimeMultipart multipart = new MimeMultipart("related");
BodyPart bodyPart = new MimeBodyPart();
bodyPart.setContent(CONTENT, "text/html; charset=utf-8");
multipart.addBodyPart(bodyPart);
message.setContent(multipart);
// send msg
message.setRecipient(Message.RecipientType.TO, new InternetAddress(mailTo));
Transport transport = session.getTransport();
transport.connect(server, username, pass);
Transport.send(message, username, pass);
resp.getWriter().print("Mail was send successfully");
return;
} catch (MessagingException ex) {
Logger.getLogger(Email.class.getName()).log(Level.SEVERE, null, ex);
}
} catch (UnsupportedEncodingException ex) {
Logger.getLogger(Email.class.getName()).log(Level.SEVERE, null, ex);
}
resp.getWriter().print("Sending mail failed");
}
最佳答案
首先,修复所有这些 common JavaMail mistakes .
如果您可以连接到一台远程服务器,但无法连接到另一台远程服务器,则该服务器的配置有误,或者您的防火墙阻止了连接。 JavaMail 常见问题解答有 tips for debugging connection problems .
关于javax.mail 不想从我的 Web 应用程序发送邮件,但它从我的控制台应用程序发送邮件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55042869/
我正在通过 labrepl 工作,我看到了一些遵循此模式的代码: ;; Pattern (apply #(apply f %&) coll) ;; Concrete example user=> (a
我从未向应用商店提交过应用,但我会在不久的将来提交。 到目前为止,我对为 iPhone 而非 iPad 进行设计感到很自在。 我了解,通过将通用PAID 应用放到应用商店,客户只需支付一次就可以同时使
我有一个应用程序,它使用不同的 Facebook 应用程序(2 个不同的 AppID)在 Facebook 上发布并显示它是“通过 iPhone”/“通过 iPad”。 当 Facebook 应用程序
我有一个要求,我们必须通过将网站源文件保存在本地 iOS 应用程序中来在 iOS 应用程序 Webview 中运行网站。 Angular 需要服务器来运行应用程序,但由于我们将文件保存在本地,我们无法
所以我有一个单页客户端应用程序。 正常流程: 应用程序 -> OAuth2 服务器 -> 应用程序 我们有自己的 OAuth2 服务器,因此人们可以登录应用程序并获取与用户实体关联的 access_t
假设我有一个安装在用户设备上的 Android 应用程序 A,我的应用程序有一个 AppWidget,我们可以让其他 Android 开发人员在其中以每次安装成本为基础发布他们的应用程序推广广告。因此
Secrets of the JavaScript Ninja中有一个例子它提供了以下代码来绕过 JavaScript 的 Math.min() 函数,该函数需要一个可变长度列表。 Example:
当我分别将数组和对象传递给 function.apply() 时,我得到 NaN 的 o/p,但是当我传递对象和数组时,我得到一个数字。为什么会发生这种情况? 由于数组也被视为对象,为什么我无法使用它
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界. 这篇CFSDN的博客文章ASP转换格林威治时间函数DateDiff()应用由作者收集整理,如果你
我正在将列表传递给 map并且想要返回一个带有合并名称的 data.frame 对象。 例如: library(tidyverse) library(broom) mtcars %>% spl
我有一个非常基本的问题,但我不知道如何实现它:我有一个返回数据框,其中每个工具的返回值是按行排列的: tmp<-as.data.frame(t(data.frame(a=rnorm(250,0,1)
我正在使用我的 FB 应用创建群组并邀请用户加入我的应用群组,第一次一切正常。当我尝试创建另一个组时,出现以下错误: {"(OAuthException - #4009) (#4009) 在有更多用户
我们正在开发一款类似于“会说话的本”应用程序的 child 应用程序。它包含大量用于交互式动画的 JPEG 图像序列。 问题是动画在 iPad Air 上播放正常,但在 iPad 2 上播放缓慢或滞后
我关注 clojure 一段时间了,它的一些功能非常令人兴奋(持久数据结构、函数式方法、不可变状态)。然而,由于我仍在学习,我想了解如何在实际场景中应用,证明其好处,然后演化并应用于更复杂的问题。即,
我开发了一个仅使用挪威语的应用程序。该应用程序不使用本地化,因为它应该仅以一种语言(挪威语)显示。但是,我已在 Info.plist 文件中将“本地化 native 开发区域”设置为“no”。我还使用
读完 Anthony's response 后上a style-related parser question ,我试图说服自己编写单体解析器仍然可以相当紧凑。 所以而不是 reference ::
multicore 库中是否有类似 sapply 的东西?还是我必须 unlist(mclapply(..)) 才能实现这一点? 如果它不存在:推理是什么? 提前致谢,如果这是一个愚蠢的问题,我们深表
我喜欢在窗口中弹出结果,以便更容易查看和查找(例如,它们不会随着控制台继续滚动而丢失)。一种方法是使用 sink() 和 file.show()。例如: y <- rnorm(100); x <- r
我有一个如下所示的 spring mvc Controller @RequestMapping(value="/new", method=RequestMethod.POST) public Stri
我正在阅读 StructureMap关于依赖注入(inject),首先有两部分初始化映射,具体类类型的接口(interface),另一部分只是实例化(请求实例)。 第一部分需要配置和设置,这是在 Bo
我是一名优秀的程序员,十分优秀!