API JavaMail - Guide rapide
L'API JavaMail fournit une infrastructure indépendante de la plate-forme et du protocole pour créer des applications de messagerie et de messagerie. L'API JavaMail fournit un ensemble de classes abstraites définissant des objets qui composent un système de messagerie. Il s'agit d'un package optionnel (extension standard) pour la lecture, la composition et l'envoi de messages électroniques.
JavaMail fournit des éléments utilisés pour construire une interface avec un système de messagerie, y compris des composants système et des interfaces. Bien que cette spécification ne définisse aucune implémentation spécifique, JavaMail inclut plusieurs classes qui implémentent les normes de messagerie Internet RFC822 et MIME. Ces classes sont fournies dans le cadre du package de classe JavaMail.
Voici quelques-uns des protocoles pris en charge dans l'API JavaMail:
SMTP: Acronyme de Simple Mail Transfer Protocol. Il fournit un mécanisme pour livrer le courrier électronique.
POP: Acronyme de Post Office Protocol. POP est le mécanisme utilisé par la plupart des internautes pour recevoir leur courrier. Il définit la prise en charge d'une seule boîte aux lettres pour chaque utilisateur. La RFC 1939 définit ce protocole.
IMAP: Acronyme de Internet Message Access Protocol. C'est un protocole avancé pour recevoir des messages. Il prend en charge plusieurs boîtes aux lettres pour chaque utilisateur, en plus, la boîte aux lettres peut être partagée par plusieurs utilisateurs. Il est défini dans la RFC 2060.
MIME: Acronyme de Multipurpose Internet Mail Extensions. . Ce n'est pas un protocole de transfert de courrier. Au lieu de cela, il définit le contenu de ce qui est transféré: le format des messages, des pièces jointes, etc. Il existe de nombreux documents différents qui entrent en vigueur ici: RFC 822, RFC 2045, RFC 2046 et RFC 2047. En tant qu'utilisateur de l'API JavaMail, vous n'avez généralement pas à vous soucier de ces formats. Cependant, ces formats existent et sont utilisés par vos programmes.
NNTP and Others: De nombreux protocoles sont fournis par des fournisseurs tiers. Certains d'entre eux sont le protocole NNTP (Network News Transfer Protocol), les extensions de messagerie Internet polyvalentes sécurisées (S / MIME), etc.
Les détails de ces derniers seront traités dans les chapitres suivants.
Architecture
Comme indiqué ci-dessus, l'application java utilise l'API JavaMail pour composer, envoyer et recevoir des e-mails.La figure suivante illustre l'architecture de JavaMail:
Le mécanisme abstrait de l'API JavaMail est similaire à d'autres API J2EE, telles que JDBC, JNDI et JMS. Comme le montre le diagramme d'architecture ci-dessus, l'API JavaMail est divisée en deux parties principales:
Une partie indépendante de l'application: une interface de programmation d'application (API) est utilisée par les composants d'application pour envoyer et recevoir des messages électroniques, indépendamment du fournisseur sous-jacent ou du protocole utilisé.
Une partie dépendant du service: une interface de fournisseur de services (SPI) parle les langues spécifiques au protocole, telles que SMTP, POP, IMAP et NNTP (Network News Transfer Protocol). Il est utilisé pour connecter un fournisseur de service de messagerie à la plate-forme J2EE.
Envoyer un e-mail à l'aide de votre application Java est assez simple mais pour commencer, vous devriez avoir JavaMail API et Java Activation Framework (JAF) installé sur votre machine.
Vous aurez besoin du JavaBeans Activation Framework (JAF)extension qui fournit le package javax.activation uniquement lorsque vous n'utilisez pas Java SE 6 ou plus récent.
Vous pouvez télécharger la dernière version de JavaMail (version 1.5.0) à partir du site Web standard de Java.
Vous pouvez télécharger la dernière version de JAF (version 1.1.1) à partir du site Web standard de Java.
Téléchargez et décompressez ces fichiers, dans les répertoires de niveau supérieur nouvellement créés, vous trouverez un certain nombre de fichiers jar pour les deux applications. Vous devez ajoutermail.jar et activation.jar fichiers dans votre CLASSPATH.
Serveur SMTP
Pour envoyer des e-mails, vous devez disposer d'un serveur SMTP chargé d'envoyer des e-mails. Vous pouvez utiliser l'une des techniques suivantes pour obtenir le serveur SMTP:
Installez et utilisez n'importe quel serveur SMTP tel que le serveur Postfix (pour Ubuntu), le serveur Apache James (Java Apache Mail Enterprise Server), etc. (ou)
Utilisez le serveur SMTP fourni par le fournisseur d'hôte par exemple: SMTP libre fournir par JangoSMTP le site est relay.jangosmtp.net (ou)
Utilisez le serveur SMTP fourni par des entreprises, par exemple gmail, yahoo, etc.
Les exemples des chapitres suivants, nous avons utilisé le serveur gratuit JangoSMTP pour envoyer des e-mails. Vous pouvez créer un compte en visitant ce site et configurer votre adresse email.
L'API JavaMail se compose de certaines interfaces et classes utilisées pour envoyer, lire et supprimer des messages électroniques. Bien qu'il existe de nombreux packages dans l'API JavaMail, couvrira les deux principaux packages qui sont fréquemment utilisés dans l'API Java Mail: package javax.mail et javax.mail.internet . Ces packages contiennent toutes les classes principales de JavaMail. Elles sont:
Classe | La description |
---|---|
javax.mail.Session | La classe clé de l'API. Un objet multithread représente la fabrique de connexions. |
javax.mail.Message | Une classe abstraite qui modélise un message électronique. Les sous-classes fournissent les implémentations réelles. |
javax.mail.Address | Une classe abstraite qui modélise les adresses (adresses de et vers) dans un message. Les sous-classes fournissent les implémentations spécifiques. |
javax.mail.Authenticator | Une classe abstraite utilisée pour protéger les ressources de messagerie sur le serveur de messagerie. |
javax.mail.Transport | Une classe abstraite qui modélise un mécanisme de transport de message pour envoyer un message électronique. |
javax.mail.Store | Une classe abstraite qui modélise une banque de messages et son protocole d'accès, pour stocker et récupérer des messages. Un magasin est divisé en dossiers. |
javax.mail.Folder | Une classe abstraite qui représente un dossier de messages électroniques. Il peut contenir des sous-dossiers. |
javax.mail.internet.MimeMessage | Le message est une classe abstraite, donc doit fonctionner avec une sous-classe; dans la plupart des cas, vous utiliserez un MimeMessage. Un MimeMessage est un message électronique qui comprend les types et les en-têtes MIME. |
javax.mail.internet.InternetAddress | Cette classe représente une adresse e-mail Internet utilisant la syntaxe de la RFC822. La syntaxe d'adresse typique est de la forme [email protected] ou Personal Name <[email protected]> . |
Voici un exemple pour envoyer un simple email. Ici, nous avons utilisé le serveur JangoSMTP via lequel les e-mails sont envoyés à notre adresse e-mail de destination. La configuration est expliquée dans le chapitre Configuration de l' environnement .
Pour envoyer un simple e-mail, les étapes suivantes sont les suivantes:
Obtenez une session
Créez un objet MimeMessage par défaut et définissez De, À, Objet dans le message.
Définissez le message réel comme:
message.setText("your text goes here");
Envoyez le message à l'aide de l'objet Transport.
Créer une classe Java
Créer un fichier de classe Java SendEmail, dont le contenu est le suivant:
package com.tutorialspoint;
import java.util.Properties;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
public class SendEmail {
public static void main(String[] args) {
// Recipient's email ID needs to be mentioned.
String to = "[email protected]";
// Sender's email ID needs to be mentioned
String from = "[email protected]";
final String username = "manishaspatil";//change accordingly
final String password = "******";//change accordingly
// Assuming you are sending email through relay.jangosmtp.net
String host = "relay.jangosmtp.net";
Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.host", host);
props.put("mail.smtp.port", "25");
// Get the Session object.
Session session = Session.getInstance(props,
new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
try {
// Create a default MimeMessage object.
Message message = new MimeMessage(session);
// Set From: header field of the header.
message.setFrom(new InternetAddress(from));
// Set To: header field of the header.
message.setRecipients(Message.RecipientType.TO,
InternetAddress.parse(to));
// Set Subject: header field
message.setSubject("Testing Subject");
// Now set the actual message
message.setText("Hello, this is sample for to check send " +
"email using JavaMailAPI ");
// Send message
Transport.send(message);
System.out.println("Sent message successfully....");
} catch (MessagingException e) {
throw new RuntimeException(e);
}
}
}
Comme nous utilisons le serveur SMTP fourni par le fournisseur d'hôte JangoSMTP, nous devons authentifier le nom d'utilisateur et le mot de passe. La classe javax.mail.PasswordAuthentication est utilisée pour authentifier le mot de passe.
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe SendEmail.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: SendEmail.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: SendEmail
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
Sent message successfully....
Comme j'envoie un e-mail à mon adresse gmail via JangoSMTP, l'e-mail suivant sera reçu dans la boîte de réception de mon compte gmail:
Voici un exemple pour envoyer un e-mail avec pièce jointe depuis votre machine. Le fichier sur la machine locale estfile.txtplacé dans / home / manisha / . Ici, nous avons utilisé le serveur JangoSMTP via lequel les e-mails sont envoyés à notre adresse e-mail de destination. La configuration est expliquée dans le chapitre Configuration de l' environnement .
Pour envoyer un e-mail avec une image intégrée, les étapes suivantes sont les suivantes:
Obtenez une session
Créez un objet MimeMessage par défaut et définissez De, À, Objet dans le message.
Définissez le message réel comme ci-dessous:
messageBodyPart.setText("This is message body");
Créez un objet MimeMultipart. Ajoutez le messageBodyPart ci-dessus avec le message réel défini, à cet objet en plusieurs parties.
Ensuite, ajoutez la pièce jointe en créant un Datahandler comme suit:
messageBodyPart = new MimeBodyPart(); String filename = "/home/manisha/file.txt"; DataSource source = new FileDataSource(filename); messageBodyPart.setDataHandler(new DataHandler(source)); messageBodyPart.setFileName(filename); multipart.addBodyPart(messageBodyPart);
Ensuite, définissez le multipart dans le message comme suit:
message.setContent(multipart);
Envoyez le message à l'aide de l'objet Transport.
Créer une classe Java
Créer un fichier de classe Java SendAttachmentInEmail, dont le contenu est le suivant:
package com.tutorialspoint;
import java.util.Properties;
import javax.activation.DataHandler;
import javax.activation.DataSource;
import javax.activation.FileDataSource;
import javax.mail.BodyPart;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.Multipart;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;
public class SendAttachmentInEmail {
public static void main(String[] args) {
// Recipient's email ID needs to be mentioned.
String to = "[email protected]";
// Sender's email ID needs to be mentioned
String from = "[email protected]";
final String username = "manishaspatil";//change accordingly
final String password = "******";//change accordingly
// Assuming you are sending email through relay.jangosmtp.net
String host = "relay.jangosmtp.net";
Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.host", host);
props.put("mail.smtp.port", "25");
// Get the Session object.
Session session = Session.getInstance(props,
new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
try {
// Create a default MimeMessage object.
Message message = new MimeMessage(session);
// Set From: header field of the header.
message.setFrom(new InternetAddress(from));
// Set To: header field of the header.
message.setRecipients(Message.RecipientType.TO,
InternetAddress.parse(to));
// Set Subject: header field
message.setSubject("Testing Subject");
// Create the message part
BodyPart messageBodyPart = new MimeBodyPart();
// Now set the actual message
messageBodyPart.setText("This is message body");
// Create a multipar message
Multipart multipart = new MimeMultipart();
// Set text message part
multipart.addBodyPart(messageBodyPart);
// Part two is attachment
messageBodyPart = new MimeBodyPart();
String filename = "/home/manisha/file.txt";
DataSource source = new FileDataSource(filename);
messageBodyPart.setDataHandler(new DataHandler(source));
messageBodyPart.setFileName(filename);
multipart.addBodyPart(messageBodyPart);
// Send the complete message parts
message.setContent(multipart);
// Send message
Transport.send(message);
System.out.println("Sent message successfully....");
} catch (MessagingException e) {
throw new RuntimeException(e);
}
}
}
Comme nous utilisons le serveur SMTP fourni par le fournisseur d'hôte JangoSMTP, nous devons authentifier le nom d'utilisateur et le mot de passe. La classe javax.mail.PasswordAuthentication est utilisée pour authentifier le mot de passe.
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe SendAttachmentInEmail.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: SendAttachmentInEmail.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: SendAttachmentInEmail
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
Sent message successfully....
Comme j'envoie un e-mail à mon adresse gmail via JangoSMTP, l'e-mail suivant sera reçu dans la boîte de réception de mon compte gmail:
Voici un exemple pour envoyer un e-mail HTML depuis votre machine. Ici, nous avons utilisé le serveur JangoSMTP via lequel les e-mails sont envoyés à notre adresse e-mail de destination. La configuration est expliquée dans le chapitre Configuration de l' environnement .
Cet exemple est très similaire à l'envoi d'un simple courrier électronique, sauf que, ici, nous utilisons la méthode setContent () pour définir le contenu dont le deuxième argument est "text / html" pour spécifier que le contenu HTML est inclus dans le message. En utilisant cet exemple, vous pouvez envoyer un contenu HTML aussi volumineux que vous le souhaitez.
Pour envoyer un e-mail avec du contenu HTML, les étapes suivantes sont les suivantes:
Obtenez une session
Créez un objet MimeMessage par défaut et définissez De, À, Objet dans le message.
Définissez le message réel en utilisant la méthode setContent () comme ci-dessous:
message.setContent("<h1>This is actual message embedded in HTML tags</h1>", "text/html");
Envoyez le message à l'aide de l'objet Transport.
Créer une classe Java
Créer un fichier de classe Java SendHTMLEmail, dont le contenu est le suivant:
package com.tutorialspoint;
import java.util.Properties;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
public class SendHTMLEmail {
public static void main(String[] args) {
// Recipient's email ID needs to be mentioned.
String to = "[email protected]";
// Sender's email ID needs to be mentioned
String from = "[email protected]";
final String username = "manishaspatil";//change accordingly
final String password = "******";//change accordingly
// Assuming you are sending email through relay.jangosmtp.net
String host = "relay.jangosmtp.net";
Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.host", host);
props.put("mail.smtp.port", "25");
// Get the Session object.
Session session = Session.getInstance(props,
new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
try {
// Create a default MimeMessage object.
Message message = new MimeMessage(session);
// Set From: header field of the header.
message.setFrom(new InternetAddress(from));
// Set To: header field of the header.
message.setRecipients(Message.RecipientType.TO,
InternetAddress.parse(to));
// Set Subject: header field
message.setSubject("Testing Subject");
// Send the actual HTML message, as big as you like
message.setContent(
"<h1>This is actual message embedded in HTML tags</h1>",
"text/html");
// Send message
Transport.send(message);
System.out.println("Sent message successfully....");
} catch (MessagingException e) {
e.printStackTrace();
throw new RuntimeException(e);
}
}
}
Comme nous utilisons le serveur SMTP fourni par le fournisseur d'hôte JangoSMTP, nous devons authentifier le nom d'utilisateur et le mot de passe. La classe javax.mail.PasswordAuthentication est utilisée pour authentifier le mot de passe.
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe SendHTMLEmail.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: SendHTMLEmail.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: SendHTMLEmail
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
Sent message successfully....
Comme j'envoie un e-mail à mon adresse gmail via JangoSMTP, l'e-mail suivant sera reçu dans la boîte de réception de mon compte gmail:
Voici un exemple pour envoyer un e-mail HTML depuis votre machine avec une image en ligne. Ici, nous avons utilisé le serveur JangoSMTP via lequel les e-mails sont envoyés à notre adresse e-mail de destination. La configuration est expliquée dans le chapitre Configuration de l' environnement .
Pour envoyer un e-mail avec une image intégrée, les étapes suivantes sont les suivantes:
Obtenez une session
Créez un objet MimeMessage par défaut et définissez De, À, Objet dans le message.
Créez un objet MimeMultipart.
Dans notre exemple, nous aurons une partie HTML et une image dans l'e-mail. Commencez par créer le contenu HTML et définissez-le dans l'objet multipart comme:
// first part (the html) BodyPart messageBodyPart = new MimeBodyPart(); String htmlText = "<H1>Hello</H1><img src=\"cid:image\">"; messageBodyPart.setContent(htmlText, "text/html"); // add it multipart.addBodyPart(messageBodyPart);
Ensuite, ajoutez l'image en créant un Datahandler comme suit:
// second part (the image) messageBodyPart = new MimeBodyPart(); DataSource fds = new FileDataSource( "/home/manisha/javamail-mini-logo.png"); messageBodyPart.setDataHandler(new DataHandler(fds)); messageBodyPart.setHeader("Content-ID", "<image>");
Ensuite, définissez le multipart dans le message comme suit:
message.setContent(multipart);
Envoyez le message à l'aide de l'objet Transport.
Créer une classe Java
Créer un fichier de classe Java SendInlineImagesInEmail, dont le contenu est le suivant:
package com.tutorialspoint;
import java.util.Properties;
import javax.activation.DataHandler;
import javax.activation.DataSource;
import javax.activation.FileDataSource;
import javax.mail.BodyPart;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;
public class SendInlineImagesInEmail {
public static void main(String[] args) {
// Recipient's email ID needs to be mentioned.
String to = "[email protected]";
// Sender's email ID needs to be mentioned
String from = "[email protected]";
final String username = "manishaspatil";//change accordingly
final String password = "******";//change accordingly
// Assuming you are sending email through relay.jangosmtp.net
String host = "relay.jangosmtp.net";
Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.host", host);
props.put("mail.smtp.port", "25");
Session session = Session.getInstance(props,
new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
try {
// Create a default MimeMessage object.
Message message = new MimeMessage(session);
// Set From: header field of the header.
message.setFrom(new InternetAddress(from));
// Set To: header field of the header.
message.setRecipients(Message.RecipientType.TO,
InternetAddress.parse(to));
// Set Subject: header field
message.setSubject("Testing Subject");
// This mail has 2 part, the BODY and the embedded image
MimeMultipart multipart = new MimeMultipart("related");
// first part (the html)
BodyPart messageBodyPart = new MimeBodyPart();
String htmlText = "<H1>Hello</H1><img src=\"cid:image\">";
messageBodyPart.setContent(htmlText, "text/html");
// add it
multipart.addBodyPart(messageBodyPart);
// second part (the image)
messageBodyPart = new MimeBodyPart();
DataSource fds = new FileDataSource(
"/home/manisha/javamail-mini-logo.png");
messageBodyPart.setDataHandler(new DataHandler(fds));
messageBodyPart.setHeader("Content-ID", "<image>");
// add image to the multipart
multipart.addBodyPart(messageBodyPart);
// put everything together
message.setContent(multipart);
// Send message
Transport.send(message);
System.out.println("Sent message successfully....");
} catch (MessagingException e) {
throw new RuntimeException(e);
}
}
}
Comme nous utilisons le serveur SMTP fourni par le fournisseur d'hôte JangoSMTP, nous devons authentifier le nom d'utilisateur et le mot de passe. La classe javax.mail.PasswordAuthentication est utilisée pour authentifier le mot de passe.
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe SendInlineImagesInEmail.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: SendInlineImagesInEmail.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: SendInlineImagesInEmail
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
Sent message successfully....
Comme j'envoie un e-mail à mon adresse gmail via JangoSMTP, l'e-mail suivant sera reçu dans la boîte de réception de mon compte gmail:
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.
Dans le chapitre précédent, nous avons appris à vérifier les e-mails. Voyons maintenant comment récupérer chaque e-mail et lire son contenu. Écrivons une classe JavaFetchingEmail qui lira les types d'e-mails suivants:
Email simple
Email avec pièce jointe
E-mail avec image intégrée
Les étapes de base suivies dans le code sont les suivantes:
Obtenez l'objet Session.
Créez un objet de magasin POP3 et connectez-vous au magasin.
Créez un objet Dossier et ouvrez le dossier approprié dans votre boîte aux lettres.
Récupérez les messages.
Fermez le dossier et stockez les objets respectivement.
Créer une classe Java
Créer un fichier de classe Java FetchingEmail, dont le contenu est comme ci-dessous:
package com.tutorialspoint;
import java.io.BufferedOutputStream;
import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Date;
import java.util.Properties;
import javax.mail.Address;
import javax.mail.Folder;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.Multipart;
import javax.mail.NoSuchProviderException;
import javax.mail.Part;
import javax.mail.Session;
import javax.mail.Store;
public class FetchingEmail {
public static void fetch(String pop3Host, String storeType, String user,
String password) {
try {
// create properties field
Properties properties = new Properties();
properties.put("mail.store.protocol", "pop3");
properties.put("mail.pop3.host", pop3Host);
properties.put("mail.pop3.port", "995");
properties.put("mail.pop3.starttls.enable", "true");
Session emailSession = Session.getDefaultInstance(properties);
// emailSession.setDebug(true);
// create the POP3 store object and connect with the pop server
Store store = emailSession.getStore("pop3s");
store.connect(pop3Host, user, password);
// create the folder object and open it
Folder emailFolder = store.getFolder("INBOX");
emailFolder.open(Folder.READ_ONLY);
BufferedReader reader = new BufferedReader(new InputStreamReader(
System.in));
// 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; i < messages.length; i++) {
Message message = messages[i];
System.out.println("---------------------------------");
writePart(message);
String line = reader.readLine();
if ("YES".equals(line)) {
message.writeTo(System.out);
} else if ("QUIT".equals(line)) {
break;
}
}
// close the store and folder objects
emailFolder.close(false);
store.close();
} catch (NoSuchProviderException e) {
e.printStackTrace();
} catch (MessagingException e) {
e.printStackTrace();
} catch (IOException 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
//Call method fetch
fetch(host, mailStoreType, username, password);
}
/*
* This method checks for content-type
* based on which, it processes and
* fetches the content of the message
*/
public static void writePart(Part p) throws Exception {
if (p instanceof Message)
//Call methos writeEnvelope
writeEnvelope((Message) p);
System.out.println("----------------------------");
System.out.println("CONTENT-TYPE: " + p.getContentType());
//check if the content is plain text
if (p.isMimeType("text/plain")) {
System.out.println("This is plain text");
System.out.println("---------------------------");
System.out.println((String) p.getContent());
}
//check if the content has attachment
else if (p.isMimeType("multipart/*")) {
System.out.println("This is a Multipart");
System.out.println("---------------------------");
Multipart mp = (Multipart) p.getContent();
int count = mp.getCount();
for (int i = 0; i < count; i++)
writePart(mp.getBodyPart(i));
}
//check if the content is a nested message
else if (p.isMimeType("message/rfc822")) {
System.out.println("This is a Nested Message");
System.out.println("---------------------------");
writePart((Part) p.getContent());
}
//check if the content is an inline image
else if (p.isMimeType("image/jpeg")) {
System.out.println("--------> image/jpeg");
Object o = p.getContent();
InputStream x = (InputStream) o;
// Construct the required byte array
System.out.println("x.length = " + x.available());
int i = 0;
byte[] bArray = new byte[x.available()];
while ((i = (int) ((InputStream) x).available()) > 0) {
int result = (int) (((InputStream) x).read(bArray));
if (result == -1)
break;
}
FileOutputStream f2 = new FileOutputStream("/tmp/image.jpg");
f2.write(bArray);
}
else if (p.getContentType().contains("image/")) {
System.out.println("content type" + p.getContentType());
File f = new File("image" + new Date().getTime() + ".jpg");
DataOutputStream output = new DataOutputStream(
new BufferedOutputStream(new FileOutputStream(f)));
com.sun.mail.util.BASE64DecoderStream test =
(com.sun.mail.util.BASE64DecoderStream) p
.getContent();
byte[] buffer = new byte[1024];
int bytesRead;
while ((bytesRead = test.read(buffer)) != -1) {
output.write(buffer, 0, bytesRead);
}
}
else {
Object o = p.getContent();
if (o instanceof String) {
System.out.println("This is a string");
System.out.println("---------------------------");
System.out.println((String) o);
}
else if (o instanceof InputStream) {
System.out.println("This is just an input stream");
System.out.println("---------------------------");
InputStream is = (InputStream) o;
is = (InputStream) o;
int c;
while ((c = is.read()) != -1)
System.out.write(c);
}
else {
System.out.println("This is an unknown type");
System.out.println("---------------------------");
System.out.println(o.toString());
}
}
}
/*
* This method would print FROM,TO and SUBJECT of the message
*/
public static void writeEnvelope(Message m) throws Exception {
System.out.println("This is the message envelope");
System.out.println("---------------------------");
Address[] a;
// FROM
if ((a = m.getFrom()) != null) {
for (int j = 0; j < a.length; j++)
System.out.println("FROM: " + a[j].toString());
}
// TO
if ((a = m.getRecipients(Message.RecipientType.TO)) != null) {
for (int j = 0; j < a.length; j++)
System.out.println("TO: " + a[j].toString());
}
// SUBJECT
if (m.getSubject() != null)
System.out.println("SUBJECT: " + m.getSubject());
}
}
Vous pouvez activer le débogage en décommentant l'instruction emailSession.setDebug (true);
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe FetchingEmail.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: FetchingEmail.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: FetchingEmail
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
messages.length---3
---------------------------------
This is the message envelope
---------------------------
FROM: XYZ <[email protected]>
TO: ABC <[email protected]>
SUBJECT: Simple Message
----------------------------
CONTENT-TYPE: multipart/alternative; boundary=047d7b343d6ad3e4ea04e8ec6579
This is a Multipart
---------------------------
----------------------------
CONTENT-TYPE: text/plain; charset=ISO-8859-1
This is plain text
---------------------------
Hi am a simple message string....
--
Regards
xyz
This is the message envelope
---------------------------
FROM: XYZ <[email protected]>
TO: ABC <[email protected]>
SUBJECT: Attachement
----------------------------
CONTENT-TYPE: multipart/mixed; boundary=047d7b343d6a99180904e8ec6751
This is a Multipart
---------------------------
----------------------------
CONTENT-TYPE: text/plain; charset=ISO-8859-1
This is plain text
---------------------------
Hi I've an attachment.Please check
--
Regards
XYZ
----------------------------
CONTENT-TYPE: application/octet-stream; name=sample_attachement
This is just an input stream
---------------------------
Submit your Tutorials, White Papers and Articles into our Tutorials Directory. This is a tutorials database where we are keeping all the tutorials shared by the internet community for the benefit of others.
This is the message envelope
---------------------------
FROM: XYZ <[email protected]>
TO: ABC <[email protected]>
SUBJECT: Inline Image
----------------------------
CONTENT-TYPE: multipart/related; boundary=f46d04182582be803504e8ece94b
This is a Multipart
---------------------------
----------------------------
CONTENT-TYPE: text/plain; charset=ISO-8859-1
This is plain text
---------------------------
Hi I've an inline image
[image: Inline image 3]
--
Regards
XYZ
----------------------------
CONTENT-TYPE: image/png; name="javamail-mini-logo.png"
content typeimage/png; name="javamail-mini-logo.png"
Ici, vous pouvez voir qu'il y a trois e-mails dans notre boîte aux lettres. D'abord un simple mail avec le message "Salut, une chaîne de message simple ....". Le deuxième courrier contient une pièce jointe. Le contenu de la pièce jointe est également imprimé comme indiqué ci-dessus. Le troisième courrier a une image en ligne.
Nous modifierons notre CheckingMails.java à partir du chapitre Vérifier les e-mails . Son contenu est comme ci-dessous:
package com.tutorialspoint;
import java.util.Properties;
import javax.mail.Authenticator;
import javax.mail.Folder;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.NoSuchProviderException;
import javax.mail.PasswordAuthentication;
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.pop3s.host", host);
properties.put("mail.pop3s.port", "995");
properties.put("mail.pop3s.starttls.enable", "true");
// Setup authentication, get session
Session emailSession = Session.getInstance(properties,
new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(
"[email protected]", "manisha123");
}
});
// emailSession.setDebug(true);
// create the POP3 store object and connect with the pop server
Store store = emailSession.getStore("pop3s");
store.connect();
// 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);
}
}
Vous pouvez activer le débogage en décommentant l'instruction emailSession.setDebug (true);
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 pouvez voir un message similaire à celui ci-dessous sur la console de commande:
messages.length---3
---------------------------------
Email Number 1
Subject: Today is a nice day
From: XYZ <[email protected]>
Text: javax.mail.internet.MimeMultipart@45f676cb
---------------------------------
Email Number 2
Subject: hiiii....
From: XYZ <[email protected]>
Text: javax.mail.internet.MimeMultipart@37f12d4f
---------------------------------
Email Number 3
Subject: helloo
From: XYZ <[email protected]>
Text: javax.mail.internet.MimeMultipart@3ad5ba3a
Dans ce chapitre, nous verrons comment répondre à un e-mail à l'aide de l'API JavaMail. Les étapes de base suivies dans le programme ci-dessous sont:
Obtenez l'objet Session avec les détails du serveur POP et SMTP dans les propriétés. Nous aurions besoin des détails POP pour récupérer les messages et des détails SMTP pour envoyer des messages.
Créez un objet de magasin POP3 et connectez-vous au magasin.
Créez un objet Dossier et ouvrez le dossier approprié dans votre boîte aux lettres.
Récupérez les messages.
Parcourez les messages et tapez «Y» ou «y» si vous souhaitez répondre.
Obtenez toutes les informations (À, De, Objet, Contenu) du message.
Créez le message de réponse à l'aide de la méthode Message.reply (). Cette méthode configure un nouveau message avec le destinataire et le sujet appropriés. La méthode prend un paramètre booléen indiquant s'il faut répondre uniquement à l'expéditeur (faux) ou répondre à tous (vrai).
Définissez From, Text et Reply-to dans le message et envoyez-le via l'instance de l'objet Transport.
Fermez respectivement les objets Transport, Dossier et Stockage.
Ici, nous avons utilisé le serveur JangoSMTP via lequel les e-mails sont envoyés à notre adresse e-mail de destination. La configuration est expliquée dans le chapitre Configuration de l' environnement .
Créer une classe Java
Créer un fichier de classe Java ReplyToEmail, dont le contenu est le suivant:
package com.tutorialspoint;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Date;
import java.util.Properties;
import javax.mail.Folder;
import javax.mail.Message;
import javax.mail.Session;
import javax.mail.Store;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
public class ReplyToEmail {
public static void main(String args[])
{
Date date = null;
Properties properties = new Properties();
properties.put("mail.store.protocol", "pop3");
properties.put("mail.pop3s.host", "pop.gmail.com");
properties.put("mail.pop3s.port", "995");
properties.put("mail.pop3.starttls.enable", "true");
properties.put("mail.smtp.auth", "true");
properties.put("mail.smtp.starttls.enable", "true");
properties.put("mail.smtp.host", "relay.jangosmtp.net");
properties.put("mail.smtp.port", "25");
Session session = Session.getDefaultInstance(properties);
// session.setDebug(true);
try
{
// Get a Store object and connect to the current host
Store store = session.getStore("pop3s");
store.connect("pop.gmail.com", "[email protected]",
"*****");//change the user and password accordingly
Folder folder = store.getFolder("inbox");
if (!folder.exists()) {
System.out.println("inbox not found");
System.exit(0);
}
folder.open(Folder.READ_ONLY);
BufferedReader reader = new BufferedReader(new InputStreamReader(
System.in));
Message[] messages = folder.getMessages();
if (messages.length != 0) {
for (int i = 0, n = messages.length; i < n; i++) {
Message message = messages[i];
date = message.getSentDate();
// Get all the information from the message
String from = InternetAddress.toString(message.getFrom());
if (from != null) {
System.out.println("From: " + from);
}
String replyTo = InternetAddress.toString(message
.getReplyTo());
if (replyTo != null) {
System.out.println("Reply-to: " + replyTo);
}
String to = InternetAddress.toString(message
.getRecipients(Message.RecipientType.TO));
if (to != null) {
System.out.println("To: " + to);
}
String subject = message.getSubject();
if (subject != null) {
System.out.println("Subject: " + subject);
}
Date sent = message.getSentDate();
if (sent != null) {
System.out.println("Sent: " + sent);
}
System.out.print("Do you want to reply [y/n] : ");
String ans = reader.readLine();
if ("Y".equals(ans) || "y".equals(ans)) {
Message replyMessage = new MimeMessage(session);
replyMessage = (MimeMessage) message.reply(false);
replyMessage.setFrom(new InternetAddress(to));
replyMessage.setText("Thanks");
replyMessage.setReplyTo(message.getReplyTo());
// Send the message by authenticating the SMTP server
// Create a Transport instance and call the sendMessage
Transport t = session.getTransport("smtp");
try {
//connect to the SMTP server using transport instance
//change the user and password accordingly
t.connect("abc", "****");
t.sendMessage(replyMessage,
replyMessage.getAllRecipients());
} finally {
t.close();
}
System.out.println("message replied successfully ....");
// close the store and folder objects
folder.close(false);
store.close();
} else if ("n".equals(ans)) {
break;
}
}//end of for loop
} else {
System.out.println("There is no msg....");
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
Vous pouvez activer le débogage en décommentant l'instruction session.setDebug (true);
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe ReplyToEmail.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: ReplyToEmail.java
Maintenant que la classe est compilée, exécutez la commande suivante pour l'exécuter:
java -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: ReplyToEmail
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
From: ABC <[email protected]>
Reply-to: [email protected]
To: XYZ <[email protected]>
Subject: Hi today is a nice day
Sent: Thu Oct 17 15:58:37 IST 2013
Do you want to reply [y/n] : y
message replied successfully ....
Vérifiez la boîte de réception à laquelle le courrier a été envoyé. Dans notre cas, le message reçu ressemble à ceci:
Dans ce chapitre, nous verrons comment transférer un e-mail à l'aide de l'API JavaMail. Les étapes de base suivies dans le programme ci-dessous sont:
Obtenez l'objet Session avec les détails du serveur POP et SMTP dans les propriétés. Nous aurions besoin des détails POP pour récupérer les messages et des détails SMTP pour envoyer des messages.
Créez un objet de magasin POP3 et connectez-vous au magasin.
Créez un objet Dossier et ouvrez le dossier approprié dans votre boîte aux lettres.
Récupérez les messages.
Parcourez les messages et tapez "Y" ou "y" si vous souhaitez transférer.
Obtenez toutes les informations (À, De, Objet, Contenu) du message.
Créez le message de transfert en travaillant avec les parties qui composent un message. La première partie serait le texte du message et une deuxième partie serait le message à transmettre. Combinez les deux dans un multipart. Ensuite, vous ajoutez le multipart à un message correctement adressé et vous l'envoyez.
Fermez respectivement les objets Transport, Dossier et Stockage.
Ici, nous avons utilisé le serveur JangoSMTP via lequel les e-mails sont envoyés à notre adresse e-mail de destination. La configuration est expliquée dans le chapitre Configuration de l' environnement .
Créer une classe Java
Créer un fichier de classe Java ForwardEmail, dont le contenu est le suivant:
package com.tutorialspoint;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Date;
import java.util.Properties;
import javax.mail.BodyPart;
import javax.mail.Folder;
import javax.mail.Message;
import javax.mail.Multipart;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Store;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;
public class ForwardEmail {
public static void main(String[] args) {
Properties properties = new Properties();
properties.put("mail.store.protocol", "pop3");
properties.put("mail.pop3s.host", "pop.gmail.com");
properties.put("mail.pop3s.port", "995");
properties.put("mail.pop3.starttls.enable", "true");
properties.put("mail.smtp.auth", "true");
properties.put("mail.smtp.host", "relay.jangosmtp.net");
properties.put("mail.smtp.port", "25");
Session session = Session.getDefaultInstance(properties);
try {
// session.setDebug(true);
// Get a Store object and connect to the current host
Store store = session.getStore("pop3s");
store.connect("pop.gmail.com", "[email protected]",
"*****");//change the user and password accordingly
// Create a Folder object and open the folder
Folder folder = store.getFolder("inbox");
folder.open(Folder.READ_ONLY);
BufferedReader reader = new BufferedReader(new InputStreamReader(
System.in));
Message[] messages = folder.getMessages();
if (messages.length != 0) {
for (int i = 0, n = messages.length; i < n; i++) {
Message message = messages[i];
// Get all the information from the message
String from = InternetAddress.toString(message.getFrom());
if (from != null) {
System.out.println("From: " + from);
}
String replyTo = InternetAddress.toString(message
.getReplyTo());
if (replyTo != null) {
System.out.println("Reply-to: " + replyTo);
}
String to = InternetAddress.toString(message
.getRecipients(Message.RecipientType.TO));
if (to != null) {
System.out.println("To: " + to);
}
String subject = message.getSubject();
if (subject != null) {
System.out.println("Subject: " + subject);
}
Date sent = message.getSentDate();
if (sent != null) {
System.out.println("Sent: " + sent);
}
System.out.print("Do you want to reply [y/n] : ");
String ans = reader.readLine();
if ("Y".equals(ans) || "y".equals(ans)) {
Message forward = new MimeMessage(session);
// Fill in header
forward.setRecipients(Message.RecipientType.TO,
InternetAddress.parse(from));
forward.setSubject("Fwd: " + message.getSubject());
forward.setFrom(new InternetAddress(to));
// Create the message part
MimeBodyPart messageBodyPart = new MimeBodyPart();
// Create a multipart message
Multipart multipart = new MimeMultipart();
// set content
messageBodyPart.setContent(message, "message/rfc822");
// Add part to multi part
multipart.addBodyPart(messageBodyPart);
// Associate multi-part with message
forward.setContent(multipart);
forward.saveChanges();
// Send the message by authenticating the SMTP server
// Create a Transport instance and call the sendMessage
Transport t = session.getTransport("smtp");
try {
//connect to the SMTP server using transport instance
//change the user and password accordingly
t.connect("abc", "*****");
t.sendMessage(forward, forward.getAllRecipients());
} finally {
t.close();
}
System.out.println("message forwarded successfully....");
// close the store and folder objects
folder.close(false);
store.close();
}// end if
}// end for
}// end if
} catch (Exception e) {
e.printStackTrace();
}
}
}
Vous pouvez activer le débogage en décommentant l'instruction session.setDebug (true);
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe ForwardEmail.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: ForwardEmail.java
Maintenant que la classe est compilée, exécutez la commande suivante pour l'exécuter:
java -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: ForwardEmail
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
From: ABC <[email protected]>
Reply-to: [email protected]
To: XYZ <[email protected]>
Subject: Hi today is a nice day
Sent: Thu Oct 17 15:58:37 IST 2013
Do you want to reply [y/n] : y
message forwarded successfully....
Vérifiez la boîte de réception à laquelle le courrier a été envoyé. Dans notre cas, le message transféré ressemblerait à ceci:
Dans ce chapitre, nous verrons comment supprimer un e-mail à l'aide de l'API JavaMail. La suppression de messages implique de travailler avec les indicateurs associés aux messages. Il existe différents indicateurs pour différents états, certains définis par le système et d'autres définis par l'utilisateur. Les indicateurs prédéfinis sont définis dans la classe interne Flags.Flag et sont répertoriés ci-dessous:
Flags.Flag.ANSWERED
Flags.Flag.DELETED
Flags.Flag.DRAFT
Flags.Flag.FLAGGED
Flags.Flag.RECENT
Flags.Flag.SEEN
Flags.Flag.USER
Le protocole POP ne prend en charge que la suppression des messages.
Les étapes de base suivies dans le programme de suppression sont:
Obtenez l'objet Session avec les détails du serveur POP et SMTP dans les propriétés. Nous aurions besoin des détails POP pour récupérer les messages et des détails SMTP pour envoyer des messages.
Créez un objet de magasin POP3 et connectez-vous au magasin.
Créez l'objet Folder et ouvrez le dossier approprié dans votre boîte aux lettres en mode READ_WRITE.
Récupère les messages du dossier de la boîte de réception.
Parcourez les messages et tapez "Y" ou "y" si vous souhaitez supprimer le message en appelant la méthode setFlag (Flags.Flag.DELETED, true) sur l'objet Message.
Les messages marqués DELETED ne sont pas réellement supprimés, jusqu'à ce que nous appelions la méthode expunge () sur l'objet Folder, ou que nous fermions le dossier avec expunge défini sur true.
Fermez l'objet magasin.
Créer une classe Java
Créer un fichier de classe Java ForwardEmail, dont le contenu est le suivant:
package com.tutorialspoint;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Properties;
import javax.mail.Flags;
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 DeleteEmail {
public static void delete(String pop3Host, String storeType, String user,
String password)
{
try
{
// get the session object
Properties properties = new Properties();
properties.put("mail.store.protocol", "pop3");
properties.put("mail.pop3s.host", pop3Host);
properties.put("mail.pop3s.port", "995");
properties.put("mail.pop3.starttls.enable", "true");
Session emailSession = Session.getDefaultInstance(properties);
// emailSession.setDebug(true);
// create the POP3 store object and connect with the pop server
Store store = emailSession.getStore("pop3s");
store.connect(pop3Host, user, password);
// create the folder object and open it
Folder emailFolder = store.getFolder("INBOX");
emailFolder.open(Folder.READ_WRITE);
BufferedReader reader = new BufferedReader(new InputStreamReader(
System.in));
// 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; i < messages.length; 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]);
String subject = message.getSubject();
System.out.print("Do you want to delete this message [y/n] ? ");
String ans = reader.readLine();
if ("Y".equals(ans) || "y".equals(ans)) {
// set the DELETE flag to true
message.setFlag(Flags.Flag.DELETED, true);
System.out.println("Marked DELETE for message: " + subject);
} else if ("n".equals(ans)) {
break;
}
}
// expunges the folder to remove messages which are marked deleted
emailFolder.close(true);
store.close();
} catch (NoSuchProviderException e) {
e.printStackTrace();
} catch (MessagingException e) {
e.printStackTrace();
} catch (IOException io) {
io.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
delete(host, mailStoreType, username, password);
}
}
Vous pouvez activer le débogage en décommentant l'instruction emailSession.setDebug (true);
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe DeleteEmail.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: DeleteEmail.java
Maintenant que la classe est compilée, exécutez la commande suivante pour l'exécuter:
java -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: DeleteEmail
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
messages.length---1
---------------------------------
Email Number 1
Subject: Testing
From: ABC <[email protected]>
Do you want to delete this message [y/n] ? y
Marked DELETE for message: Testing
Dans tous les chapitres précédents, nous avons utilisé le serveur JangoSMTP pour envoyer des e-mails. Dans ce chapitre, nous découvrirons le serveur SMTP fourni par Gmail. Gmail (entre autres) propose l'utilisation de leur serveur SMTP public gratuitement.
Les détails du serveur SMTP Gmail sont disponibles ici . Comme vous pouvez le voir dans les détails, nous pouvons utiliser une connexion TLS ou SSL pour envoyer des e-mails via le serveur SMTP de Gmail.
La procédure d'envoi d'e-mails à l'aide du serveur SMTP Gmail est similaire à celle expliquée dans le chapitre Envoi d'e - mails , sauf que nous changerions le serveur hôte. L'adresse e-mail de l'expéditeur doit être un compte Gmail actif. Essayons un exemple.
Créer une classe Java
Créer un fichier Java SendEmailUsingGMailSMTP, dont le contenu est comme ci-dessous:
package com.tutorialspoint;
import java.util.Properties;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
public class SendEmailUsingGMailSMTP {
public static void main(String[] args) {
// Recipient's email ID needs to be mentioned.
String to = "[email protected]";//change accordingly
// Sender's email ID needs to be mentioned
String from = "[email protected]";//change accordingly
final String username = "abc";//change accordingly
final String password = "*****";//change accordingly
// Assuming you are sending email through relay.jangosmtp.net
String host = "smtp.gmail.com";
Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.host", host);
props.put("mail.smtp.port", "587");
// Get the Session object.
Session session = Session.getInstance(props,
new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
try {
// Create a default MimeMessage object.
Message message = new MimeMessage(session);
// Set From: header field of the header.
message.setFrom(new InternetAddress(from));
// Set To: header field of the header.
message.setRecipients(Message.RecipientType.TO,
InternetAddress.parse(to));
// Set Subject: header field
message.setSubject("Testing Subject");
// Now set the actual message
message.setText("Hello, this is sample for to check send "
+ "email using JavaMailAPI ");
// Send message
Transport.send(message);
System.out.println("Sent message successfully....");
} catch (MessagingException e) {
throw new RuntimeException(e);
}
}
}
Ici, l'hôte est défini sur smtp.gmail.com et le port est défini sur 587 . Ici, nous avons activé la connexion TLS.
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe SendEmailUsingGMailSMTP.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: SendEmailUsingGMailSMTP.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: SendEmailUsingGMailSMTP
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
Sent message successfully....
Jusqu'à présent, nous avons travaillé dans nos chapitres précédents principalement avec le dossier INBOX. Il s'agit du dossier par défaut dans lequel réside la plupart des e-mails. Certains systèmes peuvent l'appeler INBOX et d'autres peuvent l'appeler par un autre nom. Mais, vous pouvez toujours y accéder depuis l'API JavaMail en utilisant le nom INBOX.
L'API JavaMail représente les dossiers en tant qu'instances de la classe abstraite Folder:
public abstract class Folder extends Object
Cette classe déclare des méthodes pour demander des dossiers nommés aux serveurs, supprimer des messages de dossiers, rechercher des messages particuliers dans des dossiers, répertorier les messages dans un dossier, etc.
Ouverture d'un dossier
Nous ne pouvons pas créer un dossier directement car le seul constructeur de la classe Folder est protégé . Nous pouvons obtenir un dossier à partir de:
une session
un magasin
ou un autre dossier
Toutes les classes ci-dessus ont une méthode getFolder () similaire avec une signature similaire:
public abstract Folder getFolder(String name) throws MessagingException
Certaines des méthodes qui aident à obtenir l' objet Folder sont:
Méthode | La description |
---|---|
booléen existe () | Vérifie si le dossier existe vraiment. Utilisez cette méthode avant d'obtenir l'objet Folder. |
abstract void open (mode int) | Lorsque vous obtenez un dossier , il est fermé. Utilisez cette méthode pour l'ouvrir. Le mode peut être Folder.READ_ONLY ou Folder.READ_WRITE. |
abstrait booléen isOpen () | Cette méthode retourne true si le dossier est ouvert, false s'il est fermé |
abstract void close (suppression booléenne) | Ferme le dossier. Si l' argument expunge est vrai , tous les messages supprimés dans le dossier sont supprimés du fichier réel sur le serveur. Sinon, ils sont simplement marqués comme supprimés , mais les messages peuvent toujours être restaurés. |
Informations de base sur le dossier
Voici quelques-unes des méthodes de la classe Folder qui renvoient des informations de base sur un dossier:
Méthode | La description |
---|---|
résumé String getName () | Renvoie le nom du dossier, tel que "TutorialsPoint Mail" |
résumé String getFullName () | Renvoie le nom hiérarchique complet à partir de la racine, par exemple «books / Manisha / TutorialsPoint Mail». |
URLName getURLName () | Renvoie un URLName représentant ce dossier. |
dossier abstrait getParent () | Renvoie le nom du dossier contenant ce dossier, c'est-à-dire le dossier parent. Par exemple, "Manisha" de l'exemple précédent "TutorialsPoint Mail". |
abstrait int getType () | Renvoie un int indiquant si le dossier peut contenir des messages et / ou d'autres dossiers. |
int getMode () | Il renvoie l'une des deux constantes nommées Folder.READ_ONLY ou Folder.READ_WRITE ou -1 lorsque le mode est inconnu. |
Magasin getStore () | Renvoie l'objet Store à partir duquel ce dossier a été récupéré. |
caractère abstrait getSeparator () | Renvoie le caractère délimiteur qui sépare le chemin d'accès de ce dossier des noms des sous-dossiers immédiats. |
Gestion du dossier
Voici quelques-unes des méthodes qui aident à gérer le dossier:
Méthode | La description |
---|---|
abstract boolean create (type int) | Cela crée un nouveau dossier dans le magasin de ce dossier. Où le type serait: Folder.HOLDS_MESSAGES ou Folder.HOLDS_FOLDERS. Renvoie true si le dossier est créé avec succès, sinon renvoie false . |
suppression abstraite booléenne (récurrence booléenne) | Cela supprime le dossier uniquement si le dossier est fermé. Sinon, il lève une IllegalStateException . Si recurse est vrai , les sous-dossiers sont supprimés. |
abstract boolean renameTo (dossier f) | Cela change le nom de ce dossier. Un dossier doit être fermé pour être renommé. Sinon, une IllegalStateException est levée. |
Gérer les messages dans les dossiers
Voici quelques-unes des méthodes qui aident à gérer les messages dans le dossier:
Méthode | La description |
---|---|
abstract void appendMessages (Message [] messages) | Comme son nom l'indique, les messages du tableau sont placés à la fin de ce dossier. |
void copyMessages (Message [] messages, destination du dossier) | Cela copie les messages de ce dossier dans un dossier spécifié donné en argument. |
résumé Message [] expunge () | Pour supprimer un message d'un dossier, définissez son indicateur Flags.Flag.DELETED sur true. Pour supprimer physiquement les messages supprimés d'un dossier, vous devez appeler cette méthode. |
Liste du contenu d'un dossier
Il existe quatre méthodes pour répertorier les dossiers contenus dans un dossier:
Méthode | La description |
---|---|
Liste des dossiers [] () | Cela renvoie un tableau répertoriant les dossiers que ce dossier contient. |
Dossier [] listSubscribed () | Cela renvoie un tableau répertoriant tous les dossiers abonnés que ce dossier contient. |
liste abstraite des dossiers [] (modèle de chaîne) | Ceci est similaire à la méthode list () sauf qu'elle vous permet de spécifier un modèle. Le modèle est une chaîne donnant le nom des dossiers qui correspondent. |
Folder [] listSubscribed (modèle de chaîne) | Ceci est similaire à la méthode listSubscribed () sauf qu'elle vous permet de spécifier un modèle. Le modèle est une chaîne donnant le nom des dossiers qui correspondent. |
Vérification du courrier
Méthode | La description |
---|---|
résumé int getMessageCount () | Cette méthode peut être appelée sur un dossier ouvert ou fermé. Cependant, dans le cas d'un dossier fermé, cette méthode peut (ou non) retourner -1 pour indiquer que le nombre exact de messages n'est pas facilement disponible. |
résumé booléen hasNewMessages () | Cela renvoie true si de nouveaux messages ont été ajoutés au dossier depuis sa dernière ouverture. |
int getNewMessageCount () | Il renvoie le nombre de nouveaux messages en vérifiant les messages dans le dossier dont l'indicateur RECENT est défini. |
int getUnreadMessageCount () | Cela peut être appelé sur un dossier ouvert ou fermé. Cependant, dans le cas d'un dossier fermé, il peut renvoyer -1 pour indiquer que la vraie réponse serait trop coûteuse à obtenir. |
Obtenir des messages à partir de dossiers
La classe Folder fournit quatre méthodes pour récupérer les messages des dossiers ouverts:
Méthode | La description |
---|---|
Message abstrait getMessage (int messageNumber) | Cela renvoie le nième message du dossier. Le premier message du dossier est le numéro 1. |
Message [] getMessages () | Cela renvoie un tableau d' objets Message représentant tous les messages de ce dossier. |
Message [] getMessages (int start, int end) | Cela renvoie un tableau d' objets Message du dossier, commençant par start et finissant par end, inclus. |
Message [] getMessages (int [] messageNumbers) | Cela renvoie un tableau contenant uniquement les messages spécifiquement identifiés par un numéro dans le tableau messageNumbers . |
void fetch (Message [] messages, FetchProfile fp) | Prérécupérez les éléments spécifiés dans le FetchProfile pour les messages donnés. L'argument FetchProfile spécifie les en-têtes des messages à pré-lire. |
Recherche de dossiers
Si le serveur prend en charge la recherche (comme le font de nombreux serveurs IMAP et la plupart des serveurs POP), il est facile de rechercher dans un dossier les messages répondant à certains critères. Les critères sont encodés dans des objets SearchTerm. Voici les deux méthodes de recherche:
Méthode | La description |
---|---|
Recherche de message [] (terme SearchTerm) | Recherchez dans ce dossier les messages correspondant au critère de recherche spécifié. Renvoie un tableau contenant les messages correspondants. Renvoie un tableau vide si aucune correspondance n'a été trouvée. |
Recherche de message [] (terme SearchTerm, message [] messages) | Recherchez dans le tableau de messages donné ceux qui correspondent au critère de recherche spécifié. Renvoie un tableau contenant les messages correspondants. Renvoie un tableau vide si aucune correspondance n'a été trouvée. Les objets Message spécifiés doivent appartenir à ce dossier. |
Drapeaux
La modification des indicateurs est utile lorsque vous devez modifier les indicateurs pour l'ensemble complet de messages dans un dossier. Voici les méthodes fournies dans la classe Folder:
Méthode | La description |
---|---|
void setFlags (Message [] messages, indicateur Flags, valeur booléenne) | Définit les indicateurs spécifiés sur les messages spécifiés dans le tableau. |
void setFlags (début int, fin int, indicateur Flags, valeur booléenne) | Définit les indicateurs spécifiés sur les messages numérotés du début à la fin, début et fin inclus. |
void setFlags (int [] messageNumbers, indicateur Flags, valeur booléenne) | Définit les indicateurs spécifiés sur les messages dont les numéros de message sont dans le tableau. |
Drapeaux abstraits getPermanentFlags () | Renvoie les indicateurs que ce dossier prend en charge pour tous les messages. |
Un quota dans JavaMail est un nombre ou une quantité limité ou fixe de messages dans un magasin de messagerie. Chaque demande de service de messagerie compte dans le quota d'appels d'API JavaMail. Un service de messagerie peut appliquer le critère de quota suivant:
Taille maximale des messages électroniques sortants, y compris les pièces jointes.
Taille maximale des messages électroniques entrants, y compris les pièces jointes.
Taille maximale du message lorsqu'un administrateur est un destinataire
Pour la gestion des quotas, JavaMail a les classes suivantes:
Classe | La description |
---|---|
Quota de classe publique | Cette classe représente un ensemble de quotas pour une racine de quota donnée. Chaque racine de quota a un ensemble de ressources, représenté par la classe Quota.Resource. Chaque ressource a un nom (par exemple, "STORAGE"), une utilisation actuelle et une limite d'utilisation. Cela n'a qu'une seule méthode setResourceLimit (nom de chaîne, limite longue) . |
classe statique publique Quota.Resource | Représente une ressource individuelle dans une racine de quota. |
interface publique QuotaAwareStore | Une interface implémentée par les magasins qui prennent en charge les quotas. Les méthodes getQuota et setQuota prennent en charge le modèle de quota défini par l'extension IMAP QUOTA. GmailSSLStore, GmailStore, IMAPSSLStore, IMAPStore sont les classes d'implémentation connues de cette interface. |
Voyons et exemple dans les sections suivantes qui vérifie le nom de stockage du courrier, la limite et son utilisation.
Créer une classe Java
Créer un fichier de classe Java QuotaExample, dont le contenu est le suivant:
package com.tutorialspoint;
import java.util.Properties;
import javax.mail.Quota;
import javax.mail.Session;
import javax.mail.Store;
import com.sun.mail.imap.IMAPStore;
public class QuotaExample
{
public static void main(String[] args)
{
try
{
Properties properties = new Properties();
properties.put("mail.store.protocol", "imaps");
properties.put("mail.imaps.port", "993");
properties.put("mail.imaps.starttls.enable", "true");
Session emailSession = Session.getDefaultInstance(properties);
// emailSession.setDebug(true);
// create the IMAP3 store object and connect with the pop server
Store store = emailSession.getStore("imaps");
//change the user and password accordingly
store.connect("imap.gmail.com", "[email protected]", "*****");
IMAPStore imapStore = (IMAPStore) store;
System.out.println("imapStore ---" + imapStore);
//get quota
Quota[] quotas = imapStore.getQuota("INBOX");
//Iterate through the Quotas
for (Quota quota : quotas) {
System.out.println(String.format("quotaRoot:'%s'",
quota.quotaRoot));
//Iterate through the Quota Resource
for (Quota.Resource resource : quota.resources) {
System.out.println(String.format(
"name:'%s', limit:'%s', usage:'%s'", resource.name,
resource.limit, resource.usage));
}
}
} catch (Exception e)
{
e.printStackTrace();
}
}
}
Voici la connexion au service gmail via le serveur IMAP (imap.gmail.com), car IMAPStore implémente le QuotaAwareStore. Une fois que vous obtenez l'objet Store, récupérez le tableau Quota, parcourez-le et imprimez les informations pertinentes.
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe QuotaExample.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: QuotaExample.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: QuotaExample
Vérifier la sortie
Vous devriez voir un message similaire sur la console de commande:
imapStore ---imaps://abc%[email protected]
quotaRoot:''
name:'STORAGE', limit:'15728640', usage:'513'
Un message peut être renvoyé pour plusieurs raisons. Ce problème est discuté en profondeur à rfc1211 . Seul un serveur peut déterminer l'existence d'une boîte aux lettres ou d'un nom d'utilisateur particulier. Lorsque le serveur détecte une erreur, il renvoie un message indiquant la raison de l'échec à l'expéditeur du message d'origine.
Il existe de nombreuses normes Internet couvrant les notifications d'état de livraison, mais un grand nombre de serveurs ne prennent pas en charge ces nouvelles normes, utilisant à la place des techniques ad hoc pour renvoyer ces messages d'échec. Par conséquent, il devient très difficile de corréler le message rejeté avec le message d'origine à l'origine du problème.
JavaMail inclut la prise en charge de l'analyse des notifications d'état de livraison. Il existe un certain nombre de techniques et d'heuristiques pour traiter ce problème. L'une des techniques étant les chemins de retour d'enveloppe variable. Vous pouvez définir le chemin de retour dans l'enveloppeuse comme indiqué dans l'exemple ci-dessous. Il s'agit de l'adresse à laquelle les e-mails de rebond sont envoyés. Vous souhaiterez peut-être définir cette adresse sur une adresse générique, différente de l'en-tête From:, afin de pouvoir traiter les rebonds à distance. Ceci fait en définissant la propriété mail.smtp.from dans JavaMail.
Créer une classe Java
Créer un fichier de classe Java SendEmail, dont le contenu est le suivant:
import java.util.Properties;
import javax.mail.Message;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
public class SendEmail {
public static void main(String[] args) throws Exception {
String smtpServer = "smtp.gmail.com";
int port = 587;
final String userid = "youraddress";//change accordingly
final String password = "*****";//change accordingly
String contentType = "text/html";
String subject = "test: bounce an email to a different address " +
"from the sender";
String from = "[email protected]";
String to = "[email protected]";//some invalid address
String bounceAddr = "[email protected]";//change accordingly
String body = "Test: get message to bounce to a separate email address";
Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.host", smtpServer);
props.put("mail.smtp.port", "587");
props.put("mail.transport.protocol", "smtp");
props.put("mail.smtp.from", bounceAddr);
Session mailSession = Session.getInstance(props,
new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(userid, password);
}
});
MimeMessage message = new MimeMessage(mailSession);
message.addFrom(InternetAddress.parse(from));
message.setRecipients(Message.RecipientType.TO, to);
message.setSubject(subject);
message.setContent(body, contentType);
Transport transport = mailSession.getTransport();
try {
System.out.println("Sending ....");
transport.connect(smtpServer, port, userid, password);
transport.sendMessage(message,
message.getRecipients(Message.RecipientType.TO));
System.out.println("Sending done ...");
} catch (Exception e) {
System.err.println("Error Sending: ");
e.printStackTrace();
}
transport.close();
}// end function main()
}
Ici , nous pouvons voir que la propriété mail.smtp.from est définie différente de celle de l' adresse.
Compiler et exécuter
Maintenant que notre classe est prête, compilons la classe ci-dessus. J'ai enregistré la classe SendEmail.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: SendEmail.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: SendEmail
Vérifier la sortie
Vous devriez voir le message suivant sur la console de commande:
Sending ....
Sending done ...
SMTP est un acronyme pour Simple Mail Transfer Protocol. Il s'agit d'une norme Internet pour la transmission de courrier électronique (e-mail) sur les réseaux IP (Internet Protocol). SMTP utilise le port TCP 25. Les connexions SMTP sécurisées par SSL sont connues sous le nom de SMTPS, bien que SMTPS ne soit pas un protocole à part entière.
L'API JavaMail a un package com.sun.mail.smtpqui agissent en tant que fournisseur de protocole SMTP pour accéder à un serveur SMTP. Le tableau suivant répertorie les classes incluses dans ce package:
Classe | La description |
---|---|
SMTPMessage | Cette classe est une spécialisation de la classe MimeMessage qui vous permet de spécifier diverses options et paramètres SMTP qui seront utilisés lorsque ce message est envoyé via SMTP. |
SMTPSSLTransport | Cette classe implémente la classe abstraite Transport à l'aide de SMTP sur SSL pour la soumission et le transport des messages. |
SMTPTransport | Cette classe implémente la classe abstraite Transport à l'aide de SMTP pour la soumission et le transport des messages. |
Le tableau suivant répertorie les exceptions levées:
Exception | La description |
---|---|
SMTPAddressFailedException | Cette exception est levée lorsque le message ne peut pas être envoyé. |
SMTPAddressSucceededException | Cette exception est enchaînée à partir d'une SendFailedException lorsque la propriété mail.smtp.reportsuccess a la valeur true. |
SMTPSenderFailedException | Cette exception est levée lorsque le message ne peut pas être envoyé. |
SMTPSendFailedException | Cette exception est levée lorsque le message ne peut pas être envoyé. L'exception inclut l'adresse de l'expéditeur, que le serveur de messagerie a rejetée. |
le com.sun.mail.smtple fournisseur utilise l'authentification SMTP en option. Pour utiliser l'authentification SMTP, vous devez définir la propriété mail.smtp.auth ou fournir au transport SMTP un nom d'utilisateur et un mot de passe lors de la connexion au serveur SMTP. Vous pouvez le faire en utilisant l'une des approches suivantes:
Fournissez un objet Authenticator lors de la création de votre session de messagerie et fournissez les informations de nom d'utilisateur et de mot de passe lors du rappel Authenticator. La propriété mail.smtp.user peut être définie pour fournir un nom d'utilisateur par défaut pour le rappel, mais le mot de passe devra toujours être fourni explicitement. Cette approche vous permet d'utiliser la méthode statique d'envoi de transport pour envoyer des messages. Par exemple:
Transport.send(message);
Appelez la méthode de connexion de transport explicitement avec des arguments de nom d'utilisateur et de mot de passe. Par exemple:
Transport tr = session.getTransport("smtp");
tr.connect(smtphost, username, password);
msg.saveChanges();
tr.sendMessage(msg, msg.getAllRecipients());
tr.close();
Le fournisseur de protocole SMTP prend en charge les propriétés suivantes, qui peuvent être définies dans l'objet Session JavaMail. Les propriétés sont toujours définies sous forme de chaînes. Par exemple:
props.put("mail.smtp.port", "587");
IMAP est l'acronyme de Internet Message Access Protocol. Il s'agit d'un protocole Internet de couche d'application qui permet à un client de messagerie d'accéder au courrier électronique sur un serveur de messagerie distant. Un serveur IMAP écoute généralement sur le port 143. IMAP over SSL (IMAPS) est affecté au numéro de port 993.
IMAP prend en charge les modes de fonctionnement en ligne et hors ligne. Les clients de messagerie utilisant IMAP laissent généralement des messages sur le serveur jusqu'à ce que l'utilisateur les supprime explicitement.
Paquet com.sun.mail.imapest un fournisseur de protocole IMAP pour l'API JavaMail qui permet d'accéder à une banque de messages IMAP. Le tableau ci-dessous répertorie l'interface et les classes de ce fournisseur:
Classe / Interface | La description |
---|---|
IMAPFolder.ProtocolCommand | Il s'agit d'une interface simple pour les commandes de protocole IMAP définies par l'utilisateur. |
ACL | Ceci est une classe. Une entrée de liste de contrôle d'accès pour un identifiant d'authentification particulier (utilisateur ou groupe). |
IMAPFolder | Cette classe implémente un dossier IMAP. |
IMAPFolder.FetchProfileItem | C'est une classe pour récupérer les en-têtes. |
IMAPMessage | Cette classe implémente un objet ReadableMime. |
IMAPMessage.FetchProfileCondition | Cette classe implémente le test à effectuer sur chaque message du dossier. |
IMAPSSLStore | Cette classe permet d'accéder à une banque de messages IMAP via SSL. |
IMAPStore | Cette classe permet d'accéder à une banque de messages IMAP. |
Droits | Cette classe représente l'ensemble des droits pour un identifiant d'authentification (par exemple, un utilisateur ou un groupe). |
Droits. | Cette classe intérieure représente un droit individuel. |
TrierTerm | Un critère de tri particulier, tel que défini par RFC 5256. |
Quelques points à noter au-dessus de ce fournisseur:
Ce fournisseur prend en charge les protocoles IMAP4 et IMAP4rev1.
Un IMAPStore connecté gère un pool d'objets de protocole IMAP à utiliser pour communiquer avec le serveur IMAP. Au fur et à mesure que les dossiers sont ouverts et que de nouveaux objets de protocole IMAP sont nécessaires, IMAPStore les fournira à partir du pool de connexions, ou les créera si aucun n'est disponible. Lorsqu'un dossier est fermé, son objet de protocole IMAP est renvoyé au pool de connexions si le pool.
L'objet IMAPStore connecté peut ou non maintenir un objet de protocole IMAP distinct qui fournit au magasin une connexion dédiée au serveur IMAP.
Le protocole POP (Post Office Protocol) est un protocole Internet standard de couche application utilisé par les clients de messagerie locaux pour récupérer les messages électroniques d'un serveur distant via une connexion TCP / IP. POP prend en charge les exigences simples de téléchargement et de suppression pour l'accès aux boîtes aux lettres distantes. Un serveur POP3 écoute sur le port 110 bien connu.
Paquet com.sun.mail.pop3est un fournisseur de protocole POP3 pour l'API JavaMail qui permet d'accéder à une banque de messages POP3. Le tableau ci-dessous répertorie les classes de ce package:
Nom | La description |
---|---|
POP3Folder | Un dossier POP3 (ne peut être que "INBOX"). |
POP3Message | Un message POP3. |
POP3SSLStore | Un magasin de messages POP3 utilisant SSL. |
POP3Store | Un magasin de messages POP3. |
Quelques points à noter au-dessus de ce fournisseur:
Le fournisseur POP3 prend en charge un seul dossier nommé INBOX. En raison des limitations du protocole POP3, de nombreuses fonctionnalités de l'API JavaMail telles que la notification d'événements, la gestion des dossiers, la gestion des indicateurs, etc. ne sont pas autorisées.
Le fournisseur POP3 est accessible via les API JavaMail en utilisant le nom de protocole pop3 ou une URL de la forme pop3: // utilisateur: mot de passe @ hôte: port / INBOX " .
POP3 ne prend en charge aucun indicateur permanent. Par exemple, l' indicateur Flags.Flag.RECENT ne sera jamais défini pour les messages POP3. C'est à l'application de déterminer quels messages d'une boîte aux lettres POP3 sont nouveaux .
POP3 ne prend pas en charge la méthode Folder.expunge (). Pour supprimer et effacer des messages, définissez l'indicateur Flags.Flag.DELETED sur les messages et fermez le dossier à l'aide de la méthode Folder.close (true).
POP3 ne fournit pas de date de réception , la méthode getReceivedDate renverra donc null.
Lors de l'accès aux en-têtes d'un message POP3, le fournisseur POP3 utilise la commande TOP pour récupérer tous les en-têtes, qui sont ensuite mis en cache.
Lors de l'accès au contenu d'un message POP3, le fournisseur POP3 utilise la commande RETR pour récupérer l'intégralité du message.
La méthode POP3Message.invalidate peut être utilisée pour invalider les données mises en cache sans fermer le dossier.