Path: csiph.com!x330-a1.tempe.blueboxinc.net!usenet.pasdenom.info!aioe.org!news.swapon.de!fu-berlin.de!uni-berlin.de!individual.net!not-for-mail From: Nigel Wade Newsgroups: comp.lang.java.programmer Subject: Re: JavaMail bug? Date: Mon, 25 Jul 2011 15:40:44 +0100 Lines: 104 Message-ID: <995djcFq0nU1@mid.individual.net> References: Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Trace: individual.net ZIVAa6Mn4dM3b7DAwpAgXgsGXaTr4/HSJrwlppOjveHxZJWju5 Cancel-Lock: sha1:IO6NVSzfO/I3uAT5egWIVkcBcrw= User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-GB; rv:1.9.2.18) Gecko/20110616 SUSE/3.1.11 Thunderbird/3.1.11 In-Reply-To: Xref: x330-a1.tempe.blueboxinc.net comp.lang.java.programmer:6534 On 23/07/11 21:32, Martin Gregorie wrote: > I seem to have found a JavaMail-1.4.4 bug > > If I try to open an SMTP connection by obtaining a transport instance > and then calling connect(): > > Transport tr = sesh.getTransport("smtp"); > tr.connect(host, user, password); > > where: > sesh is the current mail session, > host is "zoogz.gregorie.org" > user is "kiwi" > and password is a valid password for the user > > Transport.connect() sets up the URLName "smtp://kiwi@zoogz.gregorie.org", > which is what I expect, but then promptly fails with: > > javax.mail.MessagingException: > Could not connect to SMTP host: localhost, port: 25; > nested exception is: > java.net.ConnectException: Connection refused > > when the local Postfix MTA on the machine I'm connecting from > (zappa.gregorie.org) is stopped. > > If I restart the local Postfix instance the connect request succeeds and > the mail message is sent, but its headers clearly show that JavaMail > delivered it to the local MTA, which then passed it to the Postfix MTA on > zoogz.gregorie.org, which has been listening on port 25 the whole time. > > IOW the Transport.connect(host,user,password) method sets up its target > URL as expected but then promptly ignores it and defaults to connecting > to localhost on port 25. That certainly seems to be the problem. The MessagingException shows it's failing to connect to localhost. > Have any of you seen this problem? No, mine works as expected. At least, when I attempt a simple Transport.connect(host, user, pwd) it connects to my SMTP server on port 25. It doesn't authenticate because my SMTP server doesn't offer AUTH on port 25. But it does connect to the correct host. > Have I done anything stupid? Hard to say with the limited code you've provided. This is the code I'm testing with. import java.util.Properties; import javax.mail.Message; import javax.mail.MessagingException; import javax.mail.Session; import javax.mail.Transport; import javax.mail.internet.AddressException; import javax.mail.internet.InternetAddress; import javax.mail.internet.MimeMessage; public class TestMail { static String SMTP_SERVER = "yahoo.com"; public static void main(String[] args) { // Get system properties Properties props = System.getProperties(); // Setup mail server props.put("mail.smtp.host", SMTP_SERVER); // Get session Session session = Session.getDefaultInstance(props, null); try { Transport tr = session.getTransport("smtp"); tr.connect("mail.ion.le.ac.uk", "user", "password"); System.out.println(tr); System.out.println(tr.getURLName()); } catch(MessagingException e) { e.printStackTrace(); } } } The value of the parameter host to connect() is overriding that set in the Properties, which the correct behaviour. The URL output is: smtp://user@mail.ion.le.ac.uk I see the connection on mail.ion.le.ac.uk, and the SMTP handshake, using Wireshark. My guess is that there's a mistake somewhere in the code you haven't shown us yet. BTW, what version of JavaMail are you using? I've tested the above code with both 1.3.1 and 1.4.4. -- Nigel Wade