JavaMail application won't send email to external SMTP server

Posted by Luiz Cruz on Server Fault See other posts from Server Fault or by Luiz Cruz
Published on 2010-02-05T22:59:18Z Indexed on 2010/03/22 18:01 UTC
Read the original article Hit count: 514

This is actually a question from an exam, but I believe it could help others troubleshooting a similar situation.

In a system, an e-mail needs to be sent to a certain mailbox. The following Java code, which is part of a larger system, was developed for that. Assume that "example.com" corresponds to a valid registered internet domain.

 public void sendEmail(){

 String s1=”Warning”;
 String b1=”Contact IT support.”;
 String r1=”[email protected]”;
 String d1=”[email protected]”;
 String h1=”mx.intranet”;

 Properties p1 = new Properties();

 p1.put(“mail.host”, h1);

 Session session = Session.getDefaultInstance(p1, null);
 MimeMessage message = new MimeMessage(session);

try {
   message.setFrom(new InternetAddress(r1));
   message.addRecipient(Message.RecipientType.TO,
   new InternetAddress(d1));
   message.setSubject(s1);
   message.setText(b1);
   Transport.send(message);
  }
  catch (MessagingException e){
   System.err.println(e);
  }
}

The execution of this code, within the testing environment of an application server, does NOT work as expected. The mailbox of the "example.com" server never receives the email, even tough all string values in the code are correctly attributed.

The output for the command "netstat -np TCP" in the application server during execution is shown bellow:

Src Add         Src Port    Dest Add         Dest Port   State
192.168.5.5  54395      192.168.7.1         25      SYN_SENT
192.168.5.5  54390      192.168.7.1         110     TIME_WAIT
192.168.5.5  52001      200.218.208.118     80      CLOSE_WAIT
192.168.5.5  52050      200.218.208.118     80      ESTABLISHED
192.168.5.5  50001      200.255.94.202      25      TIME_WAIT
192.168.5.5  50000      200.255.94.202      25      ESTABLISHED

With the exception of the lines that were NAT'd, all others are associated with the Java application server, which created them after the execution of the code above.

The e-mail server used in this environment is the production server, which is online and does not require any authentication for internal connections.

Based on this situation, point out three possible causes for the problem.

© Server Fault or respective owner

Related posts about email

Related posts about smtp