FolderClosed Exception in Javamail

2019-05-17 17:41发布

问题:

Im trying to create a simple mail client in android, and I have the android version of javamail compiling and running in my app.

However, whenever I try to connect and receive mail, I get a Folder Closed exception seen below.

10-23 12:12:13.484: W/System.err(6660): javax.mail.FolderClosedException
10-23 12:12:13.484: W/System.err(6660):     at com.sun.mail.imap.IMAPMessage.getProtocol(IMAPMessage.java:149)
10-23 12:12:13.484: W/System.err(6660):     at com.sun.mail.imap.IMAPMessage.loadBODYSTRUCTURE(IMAPMessage.java:1262)
10-23 12:12:13.484: W/System.err(6660):     at com.sun.mail.imap.IMAPMessage.getDataHandler(IMAPMessage.java:616)
10-23 12:12:13.484: W/System.err(6660):     at javax.mail.internet.MimeMessage.getContent(MimeMessage.java:1398)
10-23 12:12:13.484: W/System.err(6660):     at com.teamzeta.sfu.Util.MailHelper.getMessageHTML(MailHelper.java:60)
10-23 12:12:13.484: W/System.err(6660):     at com.teamzeta.sfu.GetAsyncEmails.onPostExecute(EmailActivity.java:31)
10-23 12:12:13.484: W/System.err(6660):     at com.teamzeta.sfu.GetAsyncEmails.onPostExecute(EmailActivity.java:1)
10-23 12:12:13.484: W/System.err(6660):     at android.os.AsyncTask.finish(AsyncTask.java:631)
10-23 12:12:13.484: W/System.err(6660):     at android.os.AsyncTask.access$600(AsyncTask.java:177)
10-23 12:12:13.484: W/System.err(6660):     at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
10-23 12:12:13.484: W/System.err(6660):     at android.os.Handler.dispatchMessage(Handler.java:99)
10-23 12:12:13.484: W/System.err(6660):     at android.os.Looper.loop(Looper.java:137)
10-23 12:12:13.484: W/System.err(6660):     at android.app.ActivityThread.main(ActivityThread.java:5227)
10-23 12:12:13.484: W/System.err(6660):     at java.lang.reflect.Method.invokeNative(Native Method)
10-23 12:12:13.484: W/System.err(6660):     at java.lang.reflect.Method.invoke(Method.java:511)
10-23 12:12:13.484: W/System.err(6660):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
10-23 12:12:13.484: W/System.err(6660):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
10-23 12:12:13.494: W/System.err(6660):     at dalvik.system.NativeStart.main(Native Method)

My code is as follows:

public static Message[] getAllMail(String user, String pwd){
        String host = "imap.sfu.ca";

        final Message[] NO_MESSAGES = {};

        Properties properties = System.getProperties();
        properties.setProperty("mail.imap.socketFactory.class",
                "javax.net.ssl.SSLSocketFactory");
        properties.setProperty("mail.imap.socketFactory.port", "993");

        Session session = Session.getDefaultInstance(properties);

        try {
            Store store = session.getStore("imap");
            store.connect(host, user, pwd);

            Folder folder = store.getFolder("inbox");
            folder.open(Folder.READ_ONLY);

            Message[] messages = folder.getMessages();

            folder.close(true);
            store.close();

            Log.d("####TEAM ZETA DEBUG####", "Content: " + messages.length);

            return messages;

        } catch (NoSuchProviderException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (MessagingException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        Log.d("####TEAM ZETA DEBUG####", "Returning NO_MESSAGES");
        return NO_MESSAGES;
    }

public static String getMessageHTML(Message message){
    Object msgContent;
    try {
        msgContent = message.getContent();
        if (msgContent instanceof Multipart) {
            Multipart mp = (Multipart) msgContent;
            for (int i = 0; i < mp.getCount(); i++) {
                BodyPart bp = mp.getBodyPart(i);
                if (Pattern
                        .compile(Pattern.quote("text/html"),
                                Pattern.CASE_INSENSITIVE)
                        .matcher(bp.getContentType()).find()) {
                    // found html part
                    return (String) bp.getContent();
                } else {
                    // some other bodypart...
                }
            }
        }
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (MessagingException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }       

    return "Something went wrong";
}

I couldn't find anything helpful on the web, does anyone have an ideas why this is happening??

This is called in

class GetAsyncEmails extends AsyncTask<String, Integer, Message[]>{

@Override
protected Message[] doInBackground(String... args) {
    // TODO Auto-generated method stub
    Message[] messages = MailHelper.getAllMail(args[0], args[1]);

    return messages;
}

protected void onPostExecute(Message[] result){
    if(result.length > 1){
        Message message = result[0];
        String content = MailHelper.getMessageHTML(message);        
        System.out.println("####TEAM ZETA DEBUG####" + content);
    }
}

}

回答1:

After some tinkering with the answer another user gave (which for some reason is not here anymore) I figured out what I was doing wrong.

When I getting content from messages, the store needs to still be open in order to do so.

After looking up the FolderClosed exception, it makes things clearer: "This exception is thrown when a method is invoked on a Messaging object and the Folder that owns that object has died due to some reason."

Since I closed the folder early, and I was invoking methods I was getting the error.

So I guess you need to close the store when your application shuts down.