Java Mail Api, удаление почты из gmail
По причинам тестирования я хочу, чтобы учетная запись электронной почты была пустой каждый день, у меня есть этот код, но я не удаляю электронные письма.
public class EmailService {
private String HOST = "imap.gmail.com";
private String USERNAME = "mail@gmail.com";
private String PASSWORD = "pass";
private Properties properties;
private Store store;
private Folder inbox;
public EmailService() throws MessagingException {
this.properties = new Properties();
this.properties.put("mail.imap.host", HOST);
this.properties.put("mail.imap.port", "993");
this.properties.put("mail.imap.starttls.enable", "true");
}
public void openEmailSession() throws MessagingException, InterruptedException {
Session emailSession = Session.getInstance(this.properties);
emailSession.setDebug(true);
this.store = emailSession.getStore("imaps");
this.store.connect(HOST, USERNAME, PASSWORD);
this.inbox = this.store.getFolder("INBOX");
this.inbox.open(Folder.READ_WRITE);
}
public void closeEmailSession() throws MessagingException, IOException {
this.inbox.close(true);
this.store.close();
}
public Message[] getUserMessages() throws MessagingException, IOException {
Message[] messages = this.inbox.getMessages();
return messages;
}
public void cleanInbox() throws IOException, MessagingException {
Message[] messages = this.getUserMessages();
for (Message message :messages) {
message.setFlag(Flags.Flag.DELETED, true);
}
}
}
Когда я выполню:
emailService.openEmailSession();
emailService.cleanInbox();
emailService.closeEmailSession();
Письма исчезают из папки "Входящие", но затем я нажимаю "Вся почта", и письма все еще там, а корзина пуста. Я не понимаю, что происходит.
В настройках gmail в "Пересылка и POP/IMAP" я уже попробовал включить / выключить автоэкспонирование и три параметра в "Когда сообщение помечено как удаленное и удалено из последней видимой папки IMAP"
Но ничего не меняется... Чего мне не хватает?
Изменить: Отладочный вывод для [Gmail]/ Вся почта
DEBUG: setDebug: JavaMail version 1.5.6
DEBUG: getProvider() returning javax.mail.Provider[STORE,imaps,com.sun.mail.imap.IMAPSSLStore,Oracle]
DEBUG IMAPS: mail.imap.fetchsize: 16384
DEBUG IMAPS: mail.imap.ignorebodystructuresize: false
DEBUG IMAPS: mail.imap.statuscachetimeout: 1000
DEBUG IMAPS: mail.imap.appendbuffersize: -1
DEBUG IMAPS: mail.imap.minidletime: 10
DEBUG IMAPS: trying to connect to host "imap.gmail.com", port 993, isSSL true
* OK Gimap ready for requests from 46.25.184.193 f20mb151859057edc
A0 CAPABILITY
* CAPABILITY IMAP4rev1 UNSELECT IDLE NAMESPACE QUOTA ID XLIST CHILDREN X-GM-EXT-1 XYZZY SASL-IR AUTH=XOAUTH2 AUTH=PLAIN AUTH=PLAIN-CLIENTTOKEN AUTH=OAUTHBEARER AUTH=XOAUTH
A0 OK Thats all she wrote! f20mb151859057edc
DEBUG IMAPS: AUTH: XOAUTH2
DEBUG IMAPS: AUTH: PLAIN
DEBUG IMAPS: AUTH: PLAIN-CLIENTTOKEN
DEBUG IMAPS: AUTH: OAUTHBEARER
DEBUG IMAPS: AUTH: XOAUTH
DEBUG IMAPS: protocolConnect login, host=imap.gmail.com, user=mail@gmail.com, password=<non-null>
DEBUG IMAPS: AUTHENTICATE PLAIN command trace suppressed
DEBUG IMAPS: AUTHENTICATE PLAIN command result: A1 OK mail@gmail.com authenticated (Success)
A2 CAPABILITY
* CAPABILITY IMAP4rev1 UNSELECT IDLE NAMESPACE QUOTA ID XLIST CHILDREN X-GM-EXT-1 UIDPLUS COMPRESS=DEFLATE ENABLE MOVE CONDSTORE ESEARCH UTF8=ACCEPT LIST-EXTENDED LIST-STATUS LITERAL- APPENDLIMIT=35651584
A2 OK Success
DEBUG IMAPS: connection available -- size: 1
A3 SELECT "[Gmail]/All Mail"
* FLAGS (\Answered \Flagged \Draft \Deleted \Seen $NotPhishing $Phishing)
* OK [PERMANENTFLAGS (\Answered \Flagged \Draft \Deleted \Seen $NotPhishing $Phishing \*)] Flags permitted.
* OK [UIDVALIDITY 11] UIDs valid.
* 10 EXISTS
* 0 RECENT
* OK [UIDNEXT 3903] Predicted next UID.
* OK [HIGHESTMODSEQ 101809]
A3 OK [READ-WRITE] [Gmail]/All Mail selected. (Success)
A4 STORE 1 +FLAGS (\Deleted)
* 1 FETCH (FLAGS (\Seen \Deleted))
A4 OK Success
A5 STORE 2 +FLAGS (\Deleted)
* 2 FETCH (FLAGS (\Deleted))
A5 OK Success
A6 STORE 3 +FLAGS (\Deleted)
* 3 FETCH (FLAGS (\Seen \Deleted))
A6 OK Success
A13 OK Success
A14 CLOSE
A14 OK Returned to authenticated state. (Success)
DEBUG IMAPS: added an Authenticated connection -- size: 1
A15 LOGOUT
* BYE LOGOUT Requested
A15 OK 73 good day (Success)
DEBUG IMAPS: IMAPStore connection dead
DEBUG IMAPS: IMAPStore cleanup, force false
DEBUG IMAPS: IMAPStore cleanup done
2 ответа
Я нашел альтернативное решение, не самое лучшее для моей цели (интеграция с Дженкинсом), но пока оно работает.
Это действительно простая функция в скрипте Google, вы можете выбрать свой адрес электронной почты и запланировать функцию, как вы хотите.
https://www.google.com/script/start/
function cleanInbox() {
var threads = GmailApp.search('label:inbox');
for (var i = 0; i < threads.length; i++) {
threads[i].moveToTrash();
}
}
Вы должны сначала скопировать сообщение в папку [Gmail]/Trash
, что приведет к его немедленному удалению из текущей папки. Тогда вы должны открыть [Gmail]/Trash
и удалите сообщение. Это заставит сообщение уйти навсегда.