Für ein aktuelles Projekt musste die Anwendung per IMAP auf ein Postfach zugreifen und die Mails auslesen. Das einzige Plugin welches ich gefunden habe war für CodeIgniter, benutzte aber glücklicherweise wenig Corefunktionen was es ermöglicht hat es für CakePHP zu portieren. Es ist jetzt also sehr leicht möglich die Mails aus einem Postfach auszulesen. Im folgenden Beitrag wird gezeigt wie.
Ein Artikel von Paul Lunow, erschienen 2009 auf Interaktionsdesigner.de.
Zuletzt überarbeitet am von
Denkst Du darüber nach zu gründen? Eine Familie oder ein Startup oder beides? In der zweiten Staffel meines Podcasts spreche ich mit tollen Menschen genau darüber. Lass Dich inspirieren und abonniere meinen Podcast: Auf Apple Podcast, Spotify und auf www.gründerväter.net.
Das installierte PHP muss IMAP unterstützten. Das lässt sich herausfinden in dem die Funktion_imap_start() aufgerufen wird. Wenn die Funktion exsistiert ist alles okay. Die IMAP Componente muss in dem Ordner_app/controllers/components/ mit dem Dateinamen _Imap.php _gespeichert werden.
In einem beliebigen Controller wird die Componente wie gewohnt geladen.
$components = array('Imap');
In einem Shellprogramm (abgelegt in app/vendors/shells/) muss die Componente über Import reingeholt werden:
App::import('Component', 'Imap');
$this->Imap = new ImapComponent();
Die Componente erwartet ein Array mit den Zugangsdaten zum Postfach.
private $imap_config = array(
'imap_user' => 'test@kiwi-service.de',
'imap_pass' => 'total-geheimes-supersicheres-passwort',
'imap_flags' => '',
'imap_mailbox' => 'test@kiwi-service.de',
'imap_server' => 'kiwi-service.de',
'imap_port' => '143'
);
Die einzelnen Keys sind ja selbsterklärend. Nur die Componente muss sie noch wissen. Das geschieht per Übergabe eines Arrays:
$this->Imap->items($this->imap_config);
Oder einzelnd mit
$this->Imap->item('imap_user', 'test@kiwi-service.de');
Wenn alle Daten gesetzt sind, wird zum Postfach verbunden.
$this->Imap->connect();
Der Rückgabewert dieser Funktion ist negativ wenn es nicht funktioniert hat.
Die Anzahl der neuen Nachrichten liefert die Funktion msg_count(). Eine Liste aller Nachrichten liefert die Funktion msg_list(). Das Ergebnis ist ein mehrdimensionales Array und kann in einer Schleife durchgegangen werden.
$messages = $this->Imap->msg_list();
foreach($messages as $message) {
debug('Titel: '.$message['title']);
}
Eine gute Hilfe gegen verrückte Sonderzeichen und Kodierungen ist die Kombination von utf8_encode und quoted_printable_decode. Damit werden die meisten Umlaute richtig dargestellt. Für den Text der Mail wäre das dann innerhalb der foreach-Schleife
debug(utf8_encode(quoted_printable_decode($message['body'])));
Zu guter letzt sollte dann auch noch die Verbindung wieder getrennt werden.
$this->Imap->close();
Auch hier ein negativer Rückgabewert wenn es nicht funktioniert hat. Die Klasse bietet noch einige Funktionen, wer auf der suche ist sollte da mal einen Blick rein werfen. Ansonsten, frohes Backen!