API JavaMail - Vérification des e-mails
Il y a deux aspects à comprendre avant de passer à ce chapitre. Elles sontCheck et Fetch.
CheckUn e-mail dans JavaMail est un processus dans lequel nous ouvrons le dossier respectif dans la boîte aux lettres et recevons chaque message. Nous vérifions ici que l' en- tête de chaque message à savoir le From, To, sujet . Le contenu n'est pas lu.
FetchUn e-mail dans JavaMail est un processus dans lequel nous ouvrons le dossier respectif dans la boîte aux lettres et recevons chaque message. Parallèlement à l'en-tête, nous lisons également le contenu en reconnaissant le type de contenu.
Pour vérifier ou récupérer un e-mail à l'aide de l'API JavaMail, nous aurions besoin de serveurs POP ou IMAP. Pour vérifier et récupérer les e-mails, des classes Folder et Store sont nécessaires. Ici, nous avons utilisé le serveur POP3 de GMAIL (pop.gmail.com). Dans ce chapitre, vous apprendrez à vérifier les e-mails à l'aide de l'API JavaMail. La récupération sera traitée dans les chapitres suivants. Pour vérifier les e-mails:
Obtenez une session
Créez un objet magasin pop3 et connectez-vous au serveur pop.
Créer un objet de dossier. Ouvrez le dossier approprié dans votre boîte aux lettres.
Recevez vos messages.
Fermez les objets Store et Folder.
Créer une classe Java
Créer un fichier de classe Java CheckingMails, dont le contenu est le suivant:
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);
}
}
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe CheckingMails.java dans le répertoire:/home/manisha/JavaMailAPIExercise. Nous aurions besoin des jars javax.mail.jar et activation.jar dans le classpath. Exécutez la commande ci-dessous pour compiler la classe (les deux fichiers JAR sont placés dans le répertoire / home / manisha /) à partir de l'invite de commande:
javac -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: CheckingMails.java
Maintenant que la classe est compilée, exécutez la commande ci-dessous pour exécuter:
java -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: CheckingMails
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
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
Ici, nous avons imprimé le nombre de messages dans la BOÎTE DE RÉCEPTION qui est de 4 dans ce cas. Nous avons également imprimé le sujet, l'adresse d'expédition et le texte pour chaque message électronique.