Rheinwerk Computing < openbook > Rheinwerk Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.
 
Inhaltsverzeichnis
Vorwort
1 Neues in Java 8 und Java 7
2 Fortgeschrittene String-Verarbeitung
3 Threads und nebenläufige Programmierung
4 Datenstrukturen und Algorithmen
5 Raum und Zeit
6 Dateien, Verzeichnisse und Dateizugriffe
7 Datenströme
8 Die eXtensible Markup Language (XML)
9 Dateiformate
10 Grafische Oberflächen mit Swing
11 Grafikprogrammierung
12 JavaFX
13 Netzwerkprogrammierung
14 Verteilte Programmierung mit RMI
15 RESTful und SOAP-Web-Services
16 Technologien für die Infrastruktur
17 Typen, Reflection und Annotationen
18 Dynamische Übersetzung und Skriptsprachen
19 Logging und Monitoring
20 Sicherheitskonzepte
21 Datenbankmanagement mit JDBC
22 Java Native Interface (JNI)
23 Dienstprogramme für die Java-Umgebung
Stichwortverzeichnis

Jetzt Buch bestellen
Ihre Meinung?

Spacer
<< zurück
Java SE 8 Standard-Bibliothek von Christian Ullenboom
Das Handbuch für Java-Entwickler
Buch: Java SE 8 Standard-Bibliothek

Java SE 8 Standard-Bibliothek
Pfeil 13 Netzwerkprogrammierung
Pfeil 13.1 Grundlegende Begriffe
Pfeil 13.2 URI und URL
Pfeil 13.2.1 Die Klasse URI
Pfeil 13.2.2 Die Klasse URL
Pfeil 13.2.3 Informationen über eine URL *
Pfeil 13.2.4 Der Zugriff auf die Daten über die Klasse URL
Pfeil 13.3 Die Klasse URLConnection *
Pfeil 13.3.1 Methoden und Anwendung von URLConnection
Pfeil 13.3.2 Protokoll- und Content-Handler
Pfeil 13.3.3 Im Detail: Von der URL zur URLConnection
Pfeil 13.3.4 Der Protokoll-Handler für JAR-Dateien
Pfeil 13.3.5 Basic Authentication und Proxy-Authentifizierung
Pfeil 13.4 Mit GET und POST Daten übergeben *
Pfeil 13.4.1 Kodieren der Parameter für Serverprogramme
Pfeil 13.4.2 In Wikipedia suchen und mit GET-Request absenden
Pfeil 13.4.3 POST-Request absenden
Pfeil 13.5 Host- und IP-Adressen
Pfeil 13.5.1 Lebt der Rechner?
Pfeil 13.5.2 IP-Adresse des lokalen Hosts
Pfeil 13.5.3 Das Netz ist klasse *
Pfeil 13.5.4 NetworkInterface
Pfeil 13.6 Mit dem Socket zum Server
Pfeil 13.6.1 Das Netzwerk ist der Computer
Pfeil 13.6.2 Sockets
Pfeil 13.6.3 Eine Verbindung zum Server aufbauen
Pfeil 13.6.4 Server unter Spannung – die Ströme
Pfeil 13.6.5 Die Verbindung wieder abbauen
Pfeil 13.6.6 Informationen über den Socket *
Pfeil 13.6.7 Reine Verbindungsdaten über SocketAddress *
Pfeil 13.7 Client-Server-Kommunikation
Pfeil 13.7.1 Warten auf Verbindungen
Pfeil 13.7.2 Ein Multiplikationsserver
Pfeil 13.7.3 Blockierendes Lesen
Pfeil 13.8 Apache HttpComponents und Commons Net *
Pfeil 13.8.1 HttpComponents
Pfeil 13.8.2 Apache Commons Net
Pfeil 13.9 Arbeitsweise eines Webservers *
Pfeil 13.9.1 Das Hypertext Transfer Protocol (HTTP)
Pfeil 13.9.2 Anfragen an den Server
Pfeil 13.9.3 Die Antworten vom Server
Pfeil 13.9.4 Webserver mit com.sun.net.httpserver.HttpServer
Pfeil 13.10 Verbindungen durch einen Proxy-Server *
Pfeil 13.10.1 System-Properties
Pfeil 13.10.2 Verbindungen durch die Proxy-API
Pfeil 13.11 Datagram-Sockets *
Pfeil 13.11.1 Die Klasse DatagramSocket
Pfeil 13.11.2 Datagramme und die Klasse DatagramPacket
Pfeil 13.11.3 Auf ein hereinkommendes Paket warten
Pfeil 13.11.4 Ein Paket zum Senden vorbereiten
Pfeil 13.11.5 Methoden der Klasse DatagramPacket
Pfeil 13.11.6 Das Paket senden
Pfeil 13.12 E-Mail *
Pfeil 13.12.1 Wie eine Elektropost um die Welt geht
Pfeil 13.12.2 Das Simple Mail Transfer Protocol und RFC 822
Pfeil 13.12.3 POP (Post Office Protocol)
Pfeil 13.12.4 Die JavaMail API
Pfeil 13.12.5 E-Mails mittels POP3 abrufen
Pfeil 13.12.6 Multipart-Nachrichten verarbeiten
Pfeil 13.12.7 E-Mails versenden
Pfeil 13.12.8 Ereignisse und Suchen
Pfeil 13.13 Tiefer liegende Netzwerkeigenschaften *
Pfeil 13.13.1 MAC-Adressen auslesen
Pfeil 13.13.2 Internet Control Message Protocol (ICMP)
Pfeil 13.14 Zum Weiterlesen
 
Zum Seitenanfang

13.12E-Mail * Zur vorigen ÜberschriftZur nächsten Überschrift

E-Mail ist heute ein wichtiger Teil der modernen Kommunikation. Die Vorteile bei der Technik sind vielfältig: Das Medium ist schnell, die Nachrichtenübertragung erfolgt asynchron, und die Informationen können direkt weiterverarbeitet werden – ein Vorteil, der bei herkömmlichen Briefen nicht gegeben ist.

 
Zum Seitenanfang

13.12.1Wie eine Elektropost um die Welt geht Zur vorigen ÜberschriftZur nächsten Überschrift

In einem E-Mail-System kommen mehrere Komponenten vor, die kurz benannt werden sollen:

  • User: der Benutzer des Mail-Systems, der Nachrichten verschickt oder empfängt

  • Mail User Agent (MUA): die Schnittstelle zwischen dem Benutzer und dem Mail-System

  • Message Store (MS): Dient dem Mail User Agent zum Ablegen der Nachrichten.

  • Message Transfer Agent (MTA): Diese Komponente des Message Transfer Systems ist für die eigentliche Nachrichtenübermittlung verantwortlich.

  • Message Transfer System (MTS): die Gesamtheit der Message Transfer Agents und ihrer Verbindungen

Die Nachrichtenübermittlung läuft also über diese Komponenten, wobei der Benutzer über seinen Mail User Agent (MUA) die Nachricht erstellt. Anschließend wird diese Nachricht vom MUA an den Message Transfer Agent (MTA) übergeben. Nun ist es Aufgabe dieser Agenten, die Botschaft entweder direkt (der Empfänger ist im gleichen Netzwerk wie der Sender) oder über store and forward zu übermitteln. Danach ist der Sender aus dem Spiel, und der Empfänger nimmt die E-Mail entgegen. Der Abrufer holt sie mit dem MUA vom Ziel-MTA.

 
Zum Seitenanfang

13.12.2Das Simple Mail Transfer Protocol und RFC 822 Zur vorigen ÜberschriftZur nächsten Überschrift

Für die Übertragung von E-Mail hat sich auf breiter Basis das Simple Mail Transfer Protocol (kurz SMTP) etabliert. X.400 war durch die Standardisierung zwar auf einem guten Weg, ist aber dann stecken geblieben. SMTP ist ein Versende-Protokoll, das in RFC 2821 beschrieben ist. Zusammen mit dem RFC 822 (Standard for the Format of ARPA Internet Text Messages), das den Austausch textbasierter Nachrichten im Internet beschreibt, bildet es das Gerüst des Mail-Systems. Über RFC 822 wird nur der Aufbau der Nachrichten beschrieben – es ist kein Protokoll –, und in RFC 2821 wird das Protokoll zum Verschicken und Übertragen der Nachrichten von einem Rechner zum anderen beschrieben. Beide Systeme sind schon recht alt, das Simple Mail Transfer Protocol stammt ebenso wie der Standard für die ARPA-Internettextnachrichten aus dem Jahre 1982. Was früher noch durchging, wird heute immer mehr zum Hindernis, da die (böse) kommerzielle Welt ganz andere Weichen stellt.

Multipurpose Internet Mail Extensions (MIME)

In den Anfängen des Internets bestand eine E-Mail meistens aus lesbaren englischen Textnachrichten. Wenn denn einmal binäre Dateien verschickt werden sollten, musste der Benutzer sie unter Unix mit einem UUencode in 7-Bit-ASCII umwandeln, um sie anschließend zu verschicken. Der Standard des RFC 822 kann viele der heute anzutreffenden Daten nicht kodieren:

  • Binärdaten (zum Beispiel Audiodaten, Bilder, Video, Datenbanken)

  • Nachrichten in Sprachen mit Umlauten und Akzenten (Deutsch, Französisch)

  • Nachrichten in nichtlateinischen Schriften (Hebräisch, Russisch) oder sogar Sprachen ohne klassisches Alphabet (Chinesisch, Japanisch)

Um Abhilfe zu schaffen, wurde MIME in RFC 1341 und RFC 1521 vorgeschlagen. Um ASCII-fremde Nachrichten zu kodieren, werden fünf Nachrichten-Header definiert und die Binärdateien nach Base64-Encoding umgesetzt. Für Nachrichten, die fast nur aus ASCII-Zeichen bestehen, wäre dies aber zu großer Overhead, sodass Quoted Printing Encoding eingesetzt wird. Dies definiert lediglich alle Zeichen über 127 durch zwei hexadezimale Zeichen. Dieses Kodierungsverfahren entdecken wir oft in URLs, die von Formularen erzeugt werden, etwa http://www.google.de/search?q=r%FCssel.

 
Zum Seitenanfang

13.12.3POP (Post Office Protocol) Zur vorigen ÜberschriftZur nächsten Überschrift

Die Idee eines E-Mail-Programms ist einfach: Zunächst muss eine Verbindung zum richtigen E‐Mail-Server stehen, und anschließend lässt sich die Kommunikation mit einigen Kommandos regeln. Mit dieser Technik ist es dann möglich, eine E-Mail zu empfangen und zu senden. Nun besteht das E-Mail-System aber aus zwei Teilen: zum einen aus dem Empfänger und zum anderen aus dem Sender. Die empfangende Seite setzt auf das POP3-Protokoll, die sendende auf SMTP. Der POP3-Server sitzt auf der Empfängerseite und stellt die Infrastruktur bereit, damit die E-Mail eingesehen werden kann. Beide Systeme arbeiten also Hand in Hand. Wird mittels SMTP-Server eine E-Mail versendet, so kann sie durch den POP3-Server abgerufen werden. Alternativ lässt sich für beide Seiten auch das IMAP-Protokoll einsetzen.

 
Zum Seitenanfang

13.12.4Die JavaMail API Zur vorigen ÜberschriftZur nächsten Überschrift

Nachdem wir alles eher theoretisch betrachtet haben, wollen wir eine E-Mail-Utility-Klasse MailUtils entwickeln, um E-Mails abzurufen, zu verschicken und auch E-Mails mit Anhang zu versenden. Die Beispiele nutzen die JavaMail API, eine standardisierte API zur Kommunikation mit dem Mail-Server. Von der JavaMail API gibt es unterschiedliche Implementierungen, und wer im Java EE-Umfeld unterwegs ist, muss sich um eine Implementierung der API auch nicht kümmern, denn JavaMail ist Teil vom Java EE-Standard und somit Teil jedes Java EE-Applikationsservers. Als Entwickler von Java SE-Anwendungen müssen wir uns um eine Implementierung bemühen und können zur Referenzimplementierung von Oracle greifen, die mittlerweile auch quelloffen ist; die Webseite ist http://javamail.java.net/.

Auf der Webseite ist ein JAR-Archiv javax.mail.jar referenziert, das wir im Klassenpfad aufnehmen. JavaMail greift intern auf das JavaBeans Activation Framework zu, das seit Java 6 Teil vom JDK ist; wer noch eine alte Java-Version nutzt, muss es ebenfalls in den Klassenpfad nehmen.

Session, die Verbindung

Um eine E-Mail mit JavaMail zu verwenden, sind nicht viele Klassen zu verstehen: Session steht für eine Verbindung mit dem Mail-Server, dann unterscheidet es sich je nach Sender und Empfänger. Gemeinsam ist beiden Teilen, dass die Verbindung je nach Provider unterschiedlich konfiguriert werden muss. Dazu stellt die Session-Klasse eine getInstance(…)-Methode bereit, der ein Properties-Objekt mit Informationen über Host, Benutzername usw. übergeben werden kann. Eine andere Variante ist, über das connect(…) der Typen Store (Nachrichtenspeicher) und Transport (Sender) die Verbindungsdaten mitzugeben. Die Schlüssel für das Properties-Objekt sind standardisiert und unter http://docs.oracle.com/javaee/7/api/javax/mail/package-summary.html dokumentiert.

Für unser Beispiel soll auf Google Mail zugegriffen werden. Dazu sind ganz bestimmte Properties zu setzen – für das Empfangen andere als für das Senden. Kommen wir zum ersten Teil unserer Mail-Helferklasse:

Listing 13.25com/tutego/insel/mail/MailUtils.java, Teil 1

package com.tutego.insel.mail;

import java.io.*;
import java.util.*;
import javax.activation.*;
import javax.mail.*;
import javax.mail.internet.*;

public class MailUtils {

private MailUtils() {}

public static Session getGMailSession( String user, String pass ) {
final Properties props = new Properties();

// Zum Empfangen
props.setProperty( "mail.pop3.host", "pop.googlemail.com" );
props.setProperty( "mail.pop3.user", user );
props.setProperty( "mail.pop3.password", pass );
props.setProperty( "mail.pop3.port", "995" );
props.setProperty( "mail.pop3.auth", "true" );
props.setProperty( "mail.pop3.socketFactory.class",
"javax.net.ssl.SSLSocketFactory" );

// Zum Senden
props.setProperty( "mail.smtp.host", "smtp.gmail.com" );
props.setProperty( "mail.smtp.auth", "true" );
props.setProperty( "mail.smtp.port", "465" );
props.setProperty( "mail.smtp.socketFactory.port", "465" );
props.setProperty( "mail.smtp.socketFactory.class",
"javax.net.ssl.SSLSocketFactory" );
props.setProperty( "mail.smtp.socketFactory.fallback", "false" );

return Session.getInstance( props, new javax.mail.Authenticator() {
@Override protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication( props.getProperty( "mail.pop3.user" ),
props.getProperty( "mail.pop3.password" ) );
}
} );
// session.setDebug( true );
}
// ...
}

Bei Google Mail gibt es eine weitere Spezialität, dass ein Mail-Authenticator genutzt werden muss; er liefert beim Authentifizierungsprozess den Benutzernamen und das Passwort. Bei anderen Mail-Servern ist das nicht unbedingt erforderlich, es kommt darauf an, wie die Mail-Server die Authentifizierung vornehmen.

 
Zum Seitenanfang

13.12.5E-Mails mittels POP3 abrufen Zur vorigen ÜberschriftZur nächsten Überschrift

Steht die Verbindung zum Server, kann der Client eine Mailbox öffnen. Wir deklarieren dazu eine openPop3InboxReadOnly(Session)- und eine closeInbox(Folder)-Methode.

Listing 13.26com/tutego/insel/mail/MailUtils.java, Teil 2

public static Folder openPop3InboxReadOnly( Session session )
throws MessagingException {
Store store = session.getStore( "pop3" );
store.connect();

Folder folder = store.getFolder( "INBOX" );
folder.open( Folder.READ_ONLY );

return folder;
}
public static void closeInbox( Folder folder ) throws MessagingException {
folder.close( false );
folder.getStore().close();
}

Die Rückgabe von openPop3InboxRealOnly(Session) ist ein Folder-Objekt, und mit diesem lassen sich letztendlich die E-Mails abrufen:

Listing 13.27com/tutego/insel/mail/MailUtils.java, Teil 3

public static void printAllTextPlainMessages( Folder folder )
throws MessagingException, IOException {
for ( Message m : folder.getMessages() ) {
System.out.println( "\nNachricht:" );
System.out.println( "Von: " + Arrays.toString(m.getFrom()) );
System.out.println( "Betreff: " + m.getSubject() );
System.out.println( "Gesendet am: " + m.getSentDate() );
System.out.println( "Content-Type: " +
new ContentType( m.getContentType() ) );

if ( m.isMimeType( "text/plain" ) )
System.out.println( m.getContent() );
}
}

Die Implementierung holt sich mit getContent() den kompletten Inhalt, aber natürlich lässt sich der auch über einen Eingabestrom holen.

Im Folgenden soll das kleine Demoprogramm erst eine Verbindung mit dem Google-Mail-Server herstellen, dann den INPUT-Ordner öffnen und alle E-Mails ablaufen. Die Nachrichten werden nicht vom Server gelöscht.

Listing 13.28com/tutego/insel/mail/PrintAllMailsWithMailUtils.java, main()

Session session = MailUtils.getGMailSession(
JOptionPane.showInputDialog( "user" ),
JOptionPane.showInputDialog( "pass" ) );
Folder inbox = MailUtils.openPop3InboxReadOnly( session );
MailUtils.printAllTextPlainMessages( inbox );
MailUtils.closeInbox( inbox );

Das Programm öffnet zwei Dialoge: einen für den Benutzernamen und einen für das Passwort. Es ist jedem selbst überlassen, hier feste Strings einzukodieren.

[»]Hinweis

Um herauszufinden, ob überhaupt Nachrichten auf dem Server vorliegen, können wir auf dem aktuellen folder-Objekt die Methode getMessageCount() nutzen.

Nachricht löschen

Um eine Nachricht vom Server zu löschen, darf der Ordner nicht mit READ_ONLY geöffnet werden, sondern mit Folder.READ_WRITE. Anschließend lässt sich einer Nachricht, die durch ein Message-Objekt repräsentiert wird, mit setFlag(…) ein Lösch-Hinweis geben:

message.setFlag( Flags.Flag.DELETED, true );

Die Daten werden jedoch nur dann vom Server gelöscht, wenn zum Schluss folder.close(true) aufgerufen wird. Ohne den Aufruf von close() mit dem Argument true bleiben die Nachrichten erhalten.

 
Zum Seitenanfang

13.12.6Multipart-Nachrichten verarbeiten Zur vorigen ÜberschriftZur nächsten Überschrift

Ist die Nachricht eine Multipart-Nachricht, besteht sie aus mehreren Teilen und nicht nur einem. Technisch gesehen wird eine Multipart-Nachricht in einem speziellen MIME-Typ kodiert – neben den klassischen MIME-Typen »text/html«, »application«, »audio«, »image«, »video« ist der Typ dann »multipart« und zeigt an, dass eine E-Mail aus mehreren Teilen besteht. Alle diese Teile können wiederum selbst unterschiedliche MIME-Typen besitzen.

Für Multipart-Nachrichten bietet die JavaMail API die Klasse (Mime)Multipart an. Ist die Aussage isMimeType("multipart/*") für eine Nachricht wahr, lässt sich über die Teile iterieren und sie behandeln. Wir erweitern unsere Utility-Klasse um eine neue Methode, die sich nur die Nachrichten anschaut, die vom MIME-Typ multipart sind, und auch dann nur XML-Anhänge ausgibt, aber alle anderen Typen kommentiert.

Listing 13.29com/tutego/insel/mail/MailUtils.java, Teil 4

public static void printAllMultipartMessages( Folder folder )
throws MessagingException, IOException {
for ( Message m : folder.getMessages() ) {
if ( m.isMimeType( "text/plain" ) )
System.out.println( "Nachricht ist text/plain" );
else if ( m.isMimeType( "multipart/*" ) ) {
System.out.println( "Verarbeite multipart/* Nachricht" );
Multipart mp = (Multipart) m.getContent();

// Der erste Part ist immer die Hauptnachricht
if ( mp.getCount() > 1 ) {
Part part = mp.getBodyPart( 0 );
System.out.println( part.getContent() );
}

// Laufe über alle Teile (Anhänge)
for ( int j = 1; j < mp.getCount(); j++ ) {
Part part = mp.getBodyPart( j );
String disp = part.getDisposition();
if ( disp == null || disp.equalsIgnoreCase( Part.ATTACHMENT ) ) {
MimeBodyPart mimePart = (MimeBodyPart) part;

// Gib MIME-Typ jedes Anhangs aus; im Fall von XML die Nachricht
System.out.println( "MIME-Typ ist " + mimePart.getContentType() );
if ( mimePart.isMimeType( "text/xml" ) )
System.out.println( mimePart.getContent() );
}
}
System.out.println( "Verarbeitung abgeschlossen" );
}
}

Die erste Nachricht im Bündel ist immer die Hauptnachricht, alles andere sind Anhänge. Ausgaben könnten so aussehen:

Nachricht ist text/plain
Nachricht ist text/plain
Verarbeite multipart/* Nachricht
Hallo Peter, alles klar?
MIME-Typ ist application/msword; name=word1.doc
MIME-Typ ist application/msword; name=word2.doc
MIME-Typ ist text/xml; name="Nett.xml"
<?xml version="1.0" encoding="windows-1252"?>
<nett/>
MIME-Typ ist text/xml; name=Toll.xml
<toll/>
Verarbeitung abgeschlossen
Nachricht ist text/plain
Nachricht ist text/plain
Verarbeite multipart/* Nachricht
Gute Nacht!
MIME-Typ ist application/pdf; name=gute-nacht.pdf
Verarbeitung abgeschlossen
 
Zum Seitenanfang

13.12.7E-Mails versenden Zur vorigen ÜberschriftZur nächsten Überschrift

Um eine E-Mail mit JavaMail zu versenden, sind nicht viele Klassen zu verstehen: Session steht für eine Verbindung mit dem Mail-Server, Message (bzw. MimeMessage) für die zu versendende Nachricht, und Address repräsentiert einen Sender und die Empfänger. Die Klasse Transport ist für den Versand zuständig. Das erweitert unsere Utility-Klasse um eine Methode postMail():

Listing 13.30com/tutego/insel/mail/MailUtils.java, Teil 5

public static void postMail( Session session, String recipient,
String subject, String message )
throws MessagingException {
Message msg = new MimeMessage( session );

InternetAddress addressTo = new InternetAddress( recipient );
msg.setRecipient( Message.RecipientType.TO, addressTo );

msg.setSubject( subject );
msg.setContent( message, "text/plain" );
Transport.send( msg );
}

Und ein dazugehöriges Demoprogramm:

Listing 13.31com/tutego/insel/mail/SendMailWithMailUtils.java, main()

Session session = MailUtils.getGMailSession(
JOptionPane.showInputDialog( "user" ),
JOptionPane.showInputDialog( "pass" ) );
MailUtils.postMail( session, "a@b.c",
"Kurze Info", "Hab's verstanden!" );

[»]Hinweis

Falls das Senden nicht funktioniert, kann dies daran liegen, dass der Server mit einer »POP before send«-Authentifizierung arbeitet. Das heißt: Der Anwender muss erst mit POP die E-Mail erfragen und kann dann eine neue E-Mail senden.

MimeMultipart-Nachrichten schicken

Ein Objekt vom Typ (Mime)Multipart ist eine Containerklasse, der mit addBodyPart(BodyPart part[, int index]) diverse (Mime)BodyPart-Objekte hinzugefügt werden können. Zum Schluss – wenn die Körper aufgebaut sind – setzt auf dem Message-Objekt setContent(Multipart mp) bzw. setContent(Object obj, String type) nun nicht mehr das einfache MimeMessage-Objekt mit einem expliziten MIME-Typ auf, sondern das MimeMultipart-Objekt. Die beiden setContent(…)-Methoden werden in der Schnittstelle Part deklariert.

Unsere Utility-Klassen wollen wir um eine Methode postMultipartTextAndHtmlMail(…) erweitern, die ein Message-Objekt aus zwei Teilen zusammensetzt: zum einen aus einer normalen »text/plain«-Nachricht und zum anderen aus einer »text/html«-Nachricht. Den Konstruktor eines MimeMultipart-Objekts rufen wir mit new MimeMultipart("alternative") auf. Das bedeutet für den Mail-Client, dass die E-Mail verschiedene Versionen desselben Textes enthält und der Client sich die beste Variante aussuchen kann. Standardmäßig versendet so zum Beispiel Microsoft Outlook die E-Mails. Sie werden als reiner Text und als HTML verschickt. Lassen wir den String im Konstruktor weg, sind es einfach mehrere Anhänge.

Listing 13.32com/tutego/insel/mail/MailUtils.java, Teil 6

public static void postMultipartTextAndHtmlMail(
Session session, String recipient,
String subject, String txtMsg, String htmlMsg )
throws MessagingException {
MimeMultipart content = new MimeMultipart( "alternative" );

MimeBodyPart text = new MimeBodyPart();
text.setContent( txtMsg, "text/text" );
content.addBodyPart( text );

MimeBodyPart html = new MimeBodyPart();
html.setContent( htmlMsg, "text/html" );
content.addBodyPart( html );

Message msg = new MimeMessage( session );

InternetAddress addressTo = new InternetAddress( recipient );
msg.setRecipient( Message.RecipientType.TO, addressTo );

msg.setSubject( subject );
msg.setContent( content );
Transport.send( msg );
}

Das Beispiel sieht damit einfach aus:

Listing 13.33com/tutego/insel/mail/SendMultipartMailWithMailUtils.java, main()

Session session = MailUtils.getGMailSession(
JOptionPane.showInputDialog( "user" ),
JOptionPane.showInputDialog( "pass" ) );
MailUtils.postMultipartTextAndHtmlMail(
session, "a@b.c",
"Text und HTML beides in einer E-Mail",
"1. Text als Text",
"<html>2. Text als <b>HTML</b></html>" );

Anhänge mit senden

Anhänge kodiert die JavaMail API über DataSource-Objekte; FileDataSource steht etwa für einen Datei-Anhang. Soll dieser Anhang an die Nachricht (MimeBodyPart) angehängt werden, ist setDataHandler(DataHandler) zu verwenden. Unsere Utility-Klasse soll eine Methode bekommen, die eine Datei mit gegebenen Dateinamen in den Anhang setzt:

Listing 13.34com/tutego/insel/mail/MailUtils.java, Teil 7

public static void postAttachement( Session session, String recipient,
String subject, String message,
String filename )
throws MessagingException {
MimeMultipart content = new MimeMultipart( "mixed" );

MimeBodyPart text = new MimeBodyPart();
text.setText( message );
content.addBodyPart( text );

BodyPart messageBodyPart = new MimeBodyPart();
messageBodyPart.setDataHandler(
new DataHandler( new FileDataSource( filename ) ) );
messageBodyPart.setFileName( new File(filename).getName() );
content.addBodyPart( messageBodyPart );

Message msg = new MimeMessage( session );

InternetAddress addressTo = new InternetAddress( recipient );
msg.setRecipient( Message.RecipientType.TO, addressTo );

msg.setSubject( subject );
msg.setContent( content );
Transport.send( msg );
}

Es ist sinnvoll, mit setFileName(String) einen Namen für den Anhang zu vergeben, damit der Empfänger der E-Mail diesen Anhang einfach unter diesem Namen speichern kann.

Abschließend erstellen wir auch damit ein Demoprogramm:

Listing 13.35com/tutego/insel/mail/SendMultipartMailWithMailUtils.java, main()

Session session = MailUtils.getGMailSession(
JOptionPane.showInputDialog( "user" ),
JOptionPane.showInputDialog( "pass" ) );
MailUtils.postAttachement( session, "a@b.c", "Mail mit Anhang",
"Körper", "c:/eula.1028.txt" );
 
Zum Seitenanfang

13.12.8Ereignisse und Suchen Zur vorigen ÜberschriftZur nächsten Überschrift

Die JavaMail API bietet einige Glanzstücke, unter ihnen ein System für verschiedene Ereignisse:

Listener

Angewendet auf

Aufgaben

MessageCountListener

Folder

Findet neu eingetroffene Nachrichten (bei POP3 muss das Postfach geschlossen sein).

ConnectionListener

Service (Store, Transport), Folder

Benachrichtigung beim Öffnen, Schließen und bei Zwangstrennung

FolderListener

Folder

Ordner angelegt, umbenannt, gelöscht

MessageChangedListener

Folder

Änderung, etwa am Folder oder in Headern

StoreListener

Store

Nachricht mit Wichtigkeit ALERT oder NOTICE

TransportListener

Transport

zugestellt, nicht zugestellt, zum Teil zugestellt

Tabelle 13.6Einige Listener und ihre Horchposten

Das zweite Glanzstück ist ein Suchsystem, das JavaMail über das Paket javax.mail.search bietet. Zunächst wird ein Suchterm aus SearchTerm-Objekten aufgebaut. Diese abstrakte Basisklasse SearchTerm deklariert eine Methode match(Message), die von Unterklassen passend implementiert wird:

  • AddressTerm und die Unterklassen FromTerm und RecipientTerm vergleichen javax.mail.Address-Objekte. Address besitzt die Unterklassen InternetAddress und NewsAddress.

  • StringTerm sucht nach Teilzeichenketten. Interessant sind die Unterklassen AddressStringTerm (mit den Unterklassen FromStringTerm und RecipientStringTerm), BodyTerm, HeaderTerm, MessageIDTerm und SubjectTerm.

  • FlagTerm testet, ob Nachrichten gewisse Flags besitzen.

  • ComparisonTerm vergleicht über die Unterklassen DateTerm und IntegerComparisonTerm. Ein Datum ist durch die Unterklassen ReceivedDateTerm und SentDateTerm weiter gegliedert, ein IntegerComparisonTerm besitzt die Unterklassen MessageNumberTerm und SizeTerm.

  • AndTerm, NotTerm, OrTerm bieten Verknüpfungen zwischen Termen.

Jedes Message-Objekt deklariert zur Suche boolean match(SearchTerm term).

[zB]Beispiel

Die nächsten Anweisungen bauen ein Suchobjekt auf, das im Betreff ein »Re:« erkennt und auf die Zeichenkette »Nigeria-Connection« im Körper reagiert. search(SearchTerm) durchsucht einen Folder und liefert die Nachrichten, die auf dieses Muster passen:

SearchTerm st = new AndTerm( new SubjectTerm( "Re:" ),
new BodyTerm( "Nigeria-Connection" ) );
Message[] msgs = folder.search( st );

 


Ihre Meinung

Wie hat Ihnen das Openbook gefallen? Wir freuen uns immer über Ihre Rückmeldung. Schreiben Sie uns gerne Ihr Feedback als E-Mail an kommunikation@rheinwerk-verlag.de.

<< zurück
 Zum Rheinwerk-Shop
Zum Rheinwerk-Shop: Java SE 8 Standard-Bibliothek Java SE 8 Standard-Bibliothek
Jetzt Buch bestellen

 Buchempfehlungen
Zum Rheinwerk-Shop: Java ist auch eine Insel
Java ist auch eine Insel


Zum Rheinwerk-Shop: Professionell entwickeln mit Java EE 8
Professionell entwickeln mit Java EE 8


Zum Rheinwerk-Shop: Besser coden
Besser coden


Zum Rheinwerk-Shop: Entwurfsmuster
Entwurfsmuster


Zum Rheinwerk-Shop: IT-Projektmanagement
IT-Projektmanagement


 Lieferung
Versandkostenfrei bestellen in Deutschland, Österreich und der Schweiz
InfoInfo

 
 


Copyright © Rheinwerk Verlag GmbH 2018
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das Openbook denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt.
Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.

 
Nutzungsbestimmungen | Datenschutz | Impressum

Rheinwerk Verlag GmbH, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, service@rheinwerk-verlag.de

Cookie-Einstellungen ändern