L'article suivant fournit un aperçu de l'envoi de pièces jointes à des e-mails en Java. La fonctionnalité de connexion d'un e-mail avec les informations d'identification du fournisseur de services de messagerie est d'activer la possibilité d'envoyer des pièces jointes à un e-mail. Pour ce faire, le service d'hébergement de messagerie doit être utilisé, après quoi l'hôte de messagerie, le port, le nom d'utilisateur et le mot de passe sont saisis pour créer l'objet Session. Le service d'hébergement de messagerie propose également toutes ces spécifications en plus avec du code, qui peut utiliser n'importe quel serveur de test faux ou autre SMTP, et pour gérer la configuration et l'authentification pour JavaMail, l'objet de session fonctionnera comme une usine de connexion.
Commencez votre cours de développement de logiciels libres
Développement Web, langages de programmation, tests de logiciels et autres
L'API JavaMail propose diverses classes utiles telles que BodyPart et MimeBodyPart pour l'envoi d'e-mails avec pièces jointes. Pour apprendre les étapes d'envoi d'e-mails de l'API JavaMail pour en comprendre le sens, vous devez charger les deux fichiers jar suivants afin d'envoyer des e-mails à l'aide de l'API JavaMail :
Ensuite, créons les objets MimeMessage et MimeBodyPart maintenant que nous avons un objet Session.
Pour générer le message électronique, nous utilisons les objets suivants :
De plus, les étapes du programme de messagerie Java sont les suivantes :
Les informations d'identification du fournisseur de services de messagerie doivent être configurées. Ensuite, l'hôte de messagerie, le port, le nom d'utilisateur et le mot de passe sont saisis pour créer l'objet Session. Le service d’hébergement de messagerie offre toutes ces spécificités. Pour le code, nous pouvons utiliser n’importe quel faux serveur de test SMTP. Pour gérer la configuration et l'authentification de JavaMail, l'objet session fonctionnera comme une fabrique de connexions. Pour créer des objets MimeMessage et MimeBodyPart maintenant que nous avons un objet Session. Pour générer le message électronique, nous utilisons les objets suivants :
Code :
Message testmsg = new MimeMessage(sess); testmsg.setFrom(new InternetAddress(fromaddr)); testmsg.setRecipients(Message.RecipientType.TO, InternetAddress.parse(to)); testmsg.setSubject("Welcome to our Test Site");
Le code ci-dessus permet de créer le service Message à l'aide de l'objet de session MimeMessage. Afin que nous puissions passer la session(sess) comme paramètre de la file d'attente des messages. Avec l'aide de l'instance, nous pouvons appeler la méthode appelée setFrom() ainsi utilisée pour transmettre l'adresse De ou la liste des expéditeurs. Dans le même cas, nous pouvons appeler l'autre méthode appelée setRecipients() avec un paramètre passant comme la classe Message avec une méthode supplémentaire appelée RecipientType avec l'appel aux destinataires de courrier et en plus InternetAddress avec la méthode par défaut appelée parse(to) pour transmettre l'adresse aux destinataires. setSubject() transmet les valeurs de chaîne dans l'instance de classe Message. L'objet MimeMessage a été généré dans l'extrait ci-dessus avec les informations nécessaires, notamment de, vers et sujet. Ensuite, nous avons un objet MimeBodyPart qui contient le corps de l'e-mail. De plus, pour ajouter une pièce jointe au service de messagerie, nous devons maintenant créer un autre MimeBodyPart.
Code :
MimeBodyPart mpart = new MimeBodyPart(); mpart.attachFile(new File("path/to/file"));
The MimeBodyPart is the mail class body that created the instance and the same will be called for the method called attachFile() with additional parameters like to pass the new File object creation with file path parameters. TLS authentication is possible but different in several ways. As we can see, we are calling additional EmailUtil class methods to deliver email attachments and images even though we haven’t yet defined them.
Given below is the example mentioned:
Code:
package TestNG; 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 NewTest{ public static void main(String[] args) throws Exception { Properties props = new Properties(); props.setProperty("mail.smtp.host", "smtp.gmail.com"); props.put("mail.smtp.auth", "true"); props.put("mail.smtp.port", "465"); props.put("mail.debug", "true"); props.put("mail.smtp.socketFactory.port", "465"); props.put("mail.smtp.socketFactory.class","javax.net.ssl.SSLSocketFactory"); Session sess = Session.<em><i>getDefaultInstance</i></em>(props, new javax.mail.Authenticator() { protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication("[email protected]","xodbizaoiqijifre"); } }); try{ MimeMessage msg = new MimeMessage(sess); msg.setFrom(new InternetAddress("[email protected]")); msg.addRecipient(Message.RecipientType.<em><i>TO</i></em>,new InternetAddress("[email protected]")); msg.setSubject("Welcome To My Domain"); BodyPart mbody = new MimeBodyPart(); mbody.setText("Your Message body is sent"); MimeBodyPart mbody1 = new MimeBodyPart(); String filename = "D://articles1.txt"; DataSource source = new FileDataSource(filename); mbody1.setDataHandler(new DataHandler(source)); mbody1.setFileName(filename); Multipart mpart = new MimeMultipart(); mpart.addBodyPart(mbody); mpart.addBodyPart(mbody1); msg.setContent(mpart ); Transport.<em><i>send</i></em>(msg); System.<em><i>out</i></em>.println("Your email is sent successfully"); }catch (MessagingException ex) {ex.printStackTrace();} } }
Output:
Given below are the FAQs mentioned:
Answer: When enabling the functionality of sending email attachments, the email host, port, username, and password are entered after configuring the email with the email service provider’s credentials.
Answer: The abstract Multipart class is implemented by the MimeMultipart class, which employs MIME standards for multipart data.
Answer: Get the compose message for the session object.
Create a MimeBodyPart object and specify the message text in it. Create another MimeBodyPart object and add a DataHandler object to it. Create a Multipart object and include MimeBodyPart objects in it.
Send a message by setting the multipart object to the message object.
To obtain the session object, which contains all of the host’s data, including hostname, username, and password. Write the message, the message along with the attachment, and send it. The JavaMail API provides a platform- and protocol-neutral foundation for building mail and messaging applications. The JavaMail API makes a number of abstract classes defining the components of a mail system available.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!