API JavaMail - Verificando e-mails
Há dois aspectos que precisam ser entendidos antes de prosseguir com este capítulo. Eles sãoCheck e Fetch.
Checkenviar um e-mail em JavaMail é um processo em que abrimos a respectiva pasta na caixa de correio e obtemos cada mensagem. Aqui, verificamos apenas o cabeçalho de cada mensagem, ou seja , o assunto De, Para . O conteúdo não é lido.
Fetchenviar um e-mail em JavaMail é um processo em que abrimos a respectiva pasta na caixa de correio e obtemos cada mensagem. Junto com o cabeçalho, também lemos o conteúdo, reconhecendo o tipo de conteúdo.
Para verificar ou buscar um e-mail usando a API JavaMail, precisaríamos de servidores POP ou IMAP. Para verificar e buscar os e-mails, classes de pasta e armazenamento são necessárias. Aqui usamos o servidor POP3 do GMAIL (pop.gmail.com). Neste capítulo, você aprenderá como verificar e-mails usando a API JavaMail. A busca será tratada nos capítulos subsequentes. Para verificar e-mails:
Faça uma sessão
Crie um objeto de armazenamento pop3 e conecte-se ao servidor pop.
Crie um objeto de pasta. Abra a pasta apropriada em sua caixa de correio.
Receba suas mensagens.
Feche os objetos Store e Folder.
Criar classe Java
Crie um arquivo de classe java CheckingMails, cujos conteúdos são os seguintes:
package com.tutorialspoint;
import java.util.Properties;
import javax.mail.Folder;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.NoSuchProviderException;
import javax.mail.Session;
import javax.mail.Store;
public class CheckingMails {
public static void check(String host, String storeType, String user,
String password)
{
try {
//create properties field
Properties properties = new Properties();
properties.put("mail.pop3.host", host);
properties.put("mail.pop3.port", "995");
properties.put("mail.pop3.starttls.enable", "true");
Session emailSession = Session.getDefaultInstance(properties);
//create the POP3 store object and connect with the pop server
Store store = emailSession.getStore("pop3s");
store.connect(host, user, password);
//create the folder object and open it
Folder emailFolder = store.getFolder("INBOX");
emailFolder.open(Folder.READ_ONLY);
// retrieve the messages from the folder in an array and print it
Message[] messages = emailFolder.getMessages();
System.out.println("messages.length---" + messages.length);
for (int i = 0, n = messages.length; i < n; i++) {
Message message = messages[i];
System.out.println("---------------------------------");
System.out.println("Email Number " + (i + 1));
System.out.println("Subject: " + message.getSubject());
System.out.println("From: " + message.getFrom()[0]);
System.out.println("Text: " + message.getContent().toString());
}
//close the store and folder objects
emailFolder.close(false);
store.close();
} catch (NoSuchProviderException e) {
e.printStackTrace();
} catch (MessagingException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
String host = "pop.gmail.com";// change accordingly
String mailStoreType = "pop3";
String username = "[email protected]";// change accordingly
String password = "*****";// change accordingly
check(host, mailStoreType, username, password);
}
}
Compilar e Executar
Agora que nossa classe está pronta, vamos compilar a classe acima. Salvei a classe CheckingMails.java no diretório:/home/manisha/JavaMailAPIExercise. Precisamos dos jars javax.mail.jar e activation.jar no classpath. Execute o comando abaixo para compilar a classe (ambos os jars são colocados no diretório / home / manisha /) no prompt de comando:
javac -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: CheckingMails.java
Agora que a classe está compilada, execute o comando abaixo para executar:
java -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: CheckingMails
Verificar saída
Você deve ver a seguinte mensagem no console de comando:
messages.length---4
---------------------------------
Email Number 1
Subject: Test Mail--Fetch
From: <[email protected]>
Text: javax.mail.internet.MimeMultipart@327a5b7f
---------------------------------
Email Number 2
Subject: testing ----checking simple email
From: <[email protected]>
Text: javax.mail.internet.MimeMultipart@7f0d08bc
---------------------------------
Email Number 3
Subject: Email with attachment
From: <[email protected]>
Text: javax.mail.internet.MimeMultipart@30b8afce
---------------------------------
Email Number 4
Subject: Email with Inline image
From: <[email protected]>
Text: javax.mail.internet.MimeMultipart@2d1e165f
Aqui imprimimos o número de mensagens na CAIXA DE ENTRADA que é 4 neste caso. Também imprimimos Assunto, Endereço De e Texto para cada mensagem de e-mail.