554 Helo command rejected: Sorry, localhost is local, not remote
Vollkommen unerwartet bekomme ich nun diese Fehlermeldung beim Versenden einer E-Mail via SMTP mit der CakePHP Mail Komponente. 554 Helo command rejected: Sorry, localhost is local, not remote. Bei einer anderen Anwendung, die identischen Code verwendet und ebenfalls auf meinen lokalen Rechner läuft klappt der E-Mail-Versand. WTF…
Weder Google noch Bing finden etwas relevantes für diese Fehlermeldung. Ich habe noch ein leise Erinnerung an die Probleme die, je nach Provider, mit dem SMTP Versand auftreten können. Glücklicherweise stoplterte ich aber im Cake Handbuch über die Dokumentation zur Mail Komponente und die weisen Jungs bei CakePHP haben eine Lösung. Es ist der Sendeparameter ‘client’, den ich zuvor nie benötigte und der laut Doku nur bei nicht RFC 821 konformen SMTP Servern benötigt wird. Sobald ich für ‘client’ den Host des SMTP Server (oder irgendeinen anderen) eingetragen habe funktioniert der Mailversand.
Warum es vom gleichen Host mit den gleichen SMTP Daten einmal funktioniert und ein anderes mal nicht will sich mir aber trotzdem nicht erschliessen. Naja, es mir aber auch niemals jemand versprochen, dass man als PHP Programmierer ausschliesslich auf einer Blümchenwiese lebt
Achso, hier auch noch das entsprechende Codesample:
function prepareSmtpSending(){ $this->Email->smtpOptions = array( 'port' => 25, 'timeout' => 30, 'host' => 'mail.irgendwo.de', 'username' => 'hans', 'password' => 'wurst', 'client' => 'irgendwo.de' // <-- Die Rettung ); $this->Email->delivery = 'smtp'; }
In diesem Zusammenhang:
- SMPT 450 : Sender address rejected: Domain not found Diese kleine böse Falle hat mich gerade locker eine Stunde...
- E-Mail mit Anhang über PHP 4 versenden Immer wieder stößt man auf Server bzw. Webseiten die noch...
- CakePHP – Pagination in Verbindung mit Containable Das Behaviour Containable ist eines der Highlights bei der Arbeit...