Search code examples
javajakarta-mailimapgmail-imap

JavaMail - Using proxy server since reading gmail code isn't working when connected to office network


Below code to read gmail works fine when i'm not connected to office network

      Properties props = new Properties();        
      props.setProperty("mail.imap.ssl.enable", "true");     
      Session mailSession = Session.getInstance(props); 
      mailSession.setDebug(true);
      Store mailStore = mailSession.getStore("imap");
      mailStore.connect("imap.gmail.com", "abc@gmail.com", "pwd");

However same code doesn't work when connected to office network. Error is :

DEBUG: setDebug: JavaMail version 1.6.2
DEBUG: getProvider() returning javax.mail.Provider[STORE,imap,com.sun.mail.imap.IMAPStore,Oracle]
DEBUG IMAP: mail.imap.fetchsize: 16384
DEBUG IMAP: mail.imap.ignorebodystructuresize: false
DEBUG IMAP: mail.imap.statuscachetimeout: 1000
DEBUG IMAP: mail.imap.appendbuffersize: -1
DEBUG IMAP: mail.imap.minidletime: 10
DEBUG IMAP: closeFoldersOnStoreFailure
DEBUG IMAP: trying to connect to host "imap.gmail.com", port 993, isSSL true
com.sun.mail.util.MailConnectException: Couldn't connect to host, port: imap.gmail.com, 993; timeout -1;
  nested exception is:
    java.net.UnknownHostException: imap.gmail.com
    at com.sun.mail.imap.IMAPStore.protocolConnect(IMAPStore.java:740)
    at javax.mail.Service.connect(Service.java:366)
    at javax.mail.Service.connect(Service.java:246)
Caused by: java.net.UnknownHostException: imap.gmail.com
    at java.base/java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:220)
    at java.base/java.net.SocksSocketImpl.connect(SocksSocketImpl.java:403)
    at java.base/java.net.Socket.connect(Socket.java:608)
    at java.base/java.net.Socket.connect(Socket.java:557)
    at com.sun.mail.util.SocketFetcher.createSocket(SocketFetcher.java:359)
    at com.sun.mail.util.SocketFetcher.getSocket(SocketFetcher.java:238)
    at com.sun.mail.iap.Protocol.<init>(Protocol.java:134)
    at com.sun.mail.imap.protocol.IMAPProtocol.<init>(IMAPProtocol.java:131)
    at com.sun.mail.imap.IMAPStore.newIMAPProtocol(IMAPStore.java:763)
    at com.sun.mail.imap.IMAPStore.protocolConnect(IMAPStore.java:698)
    ... 4 more

After googling found suggestion to use proxy . As per https://javaee.github.io/javamail/FAQ#proxy Starting with JavaMail 1.6.0 we can set proxy details properties. So added these properties to the code :

        Properties props = new Properties();
        props.setProperty("mail.imap.ssl.enable", "true");
        props.setProperty("mail.protocol.proxy.host", "hostdetails");
        props.setProperty("mail.protocol.proxy.port", "80");
        //props.setProperty("mail.imap.socks.host", "hostdetails");
        //props.setProperty("mail.imap.socks.port", "80");
        Session mailSession = Session.getInstance(props);
        mailSession.setDebug(true);
        Store mailStore = mailSession.getStore("imap");
        mailStore.connect("imap.gmail.com", "abc@gmail.com", "pwd");

Got the same error. Tried adding props.setProperty("mail.imap.socks.host", "hostdetails"); as well but got the same error. Any idea how to make it work?


Solution

  • As @Bill Shannon suggested it worked after setting below properties

    props.setProperty("mail.imap.proxy.host", "hostdetails"); 
    props.setProperty("mail.imap.proxy.port", "portNumber");
    

    you can see my comments above for Bill Shannon's comments. I initially got exceptions even after adding above 2 lines and i was connected to office n/w through VPN then. Once i went to office and tested it worked with these proxy settings ! And now I've again connected to office n/w using VPN and same code is working perfectly fine !!!