簡體   English   中英

CodeIgniter電子郵件不起作用

[英]CodeIgniter Email Doesn't Work

我配置了可通過本地主機訪問的SMTP服務器。

PHP mail()命令可以正常工作,我在計划任務中使用它通過電子郵件將備份電子郵件發送為附件。

如果我使用以下代碼使用CodeIgniter v1.7.2電子郵件庫,並且CI調試輸出顯示已發送郵件,但SMTP服務器日志顯示錯誤的發件人。

        $this->CI->load->library('email');

        $config['protocol'] = 'mail';
        $config['smtp_host'] = 'localhost';
        $config['mailtype'] = 'html';
        $config['crlf']        = "\r\n";        // CHANGED FROM DEFAULTS
        $config['newline']     = "\r\n";        // CHANGED FROM DEFAULTS

        $this->CI->email->initialize($config);

        $this->CI->email->from('noreply@hiddendomain.com');
        $this->CI->email->to($_POST['email']); 

        $this->CI->email->subject('Password Reset');
        $this->CI->email->message('Testing the email class. <a href="http://www.google.co.uk">test</a>');   

        $this->CI->email->send();

這是來自PHP郵件的2條消息的日志(將域更改為hiddendomain1 / 2)

03/10/11 16:26:39   ME-I0107: [496] Relay Granted: Sender IP (127.0.0.1) is within an authorized IP range.
03/10/11 16:26:39   ME-I0149: [496] AFAB1A79683B434EAD6A415C5DAA7D52.MAI was received successfully and delivery thread was initiated
03/10/11 16:26:39   ME-I0074: [496] (Debug) End of conversation
03/10/11 16:26:39   ME-I0107: [552] Relay Granted: Sender IP (127.0.0.1) is within an authorized IP range.
03/10/11 16:26:39   ME-I0149: [552] 16B8D83CD6B040489608FCE5E9C3A177.MAI was received successfully and delivery thread was initiated
03/10/11 16:26:39   ME-I0074: [552] (Debug) End of conversation
03/10/11 16:26:40   ME-I0018: [8F72D521DC554A13AA1E0973090A75B9.MAI] Outbound message from ([SMTP:noreply@hiddendomain1.com]) requeued as [CC32D29A0BA34D9496B1602A8150B7EE.MAI] to the target domain [hiddendomain2.com]
03/10/11 16:26:40   ME-I0123: Domain [hiddendomain2.com] has MX list [mailserver.hiddendomain2.com]
03/10/11 16:26:40   ME-I0026: [CC32D29A0BA34D9496B1602A8150B7EE.MAI] Sending message
03/10/11 16:26:40   ME-I0018: [9D2654AE500442E4A90DDFD75B98C0B5.MAI] Outbound message from ([SMTP:noreply@hiddendomain1.com]) requeued as [90EF8F85B103431FB14A32F535AFFFFD.MAI] to the target domain [hiddendomain2.com]
03/10/11 16:26:40   ME-I0123: Domain [hiddendomain2.com] has MX list [mailserver.hiddendomain2.com]
03/10/11 16:26:40   ME-I0026: [90EF8F85B103431FB14A32F535AFFFFD.MAI] Sending message
03/10/11 16:26:40   ME-I0049: [CC32D29A0BA34D9496B1602A8150B7EE.MAI] Send Completed Successfully
03/10/11 16:26:41   ME-I0049: [90EF8F85B103431FB14A32F535AFFFFD.MAI] Send Completed Successfully

這是通過CodeIgniter發送后的日志,因為您可以看到CI電子郵件庫正在將<char添加到發件人地址,請問有什么幫助告訴我為什么? 這是CI的錯誤嗎?

03/10/11 16:26:42   ME-I0107: [568] Relay Granted: Sender IP (127.0.0.1) is within an authorized IP range.
03/10/11 16:26:42   ME-I0149: [568] B1D7A0FCDF44403291E8EAD33F5F144F.MAI was received successfully and delivery thread was initiated
03/10/11 16:26:42   ME-I0074: [568] (Debug) End of conversation
03/10/11 16:26:42   ME-I0018: [38DFE013802046528FAC7823871869CC.MAI] Outbound message from ([SMTP:<noreply@hiddendomain1.com]) requeued as [AC83949E463246DDBD022BBF355D4606.MAI] to the target domain [hiddendomain2.com]
03/10/11 16:26:42   ME-I0123: Domain [hiddendomain2.com] has MX list [mailserver.hiddendomain2.com]
03/10/11 16:26:42   ME-I0026: [AC83949E463246DDBD022BBF355D4606.MAI] Sending message
03/10/11 16:26:42   ME-IXXXX: [AC83949E463246DDBD022BBF355D4606.MAI] Remote server returned a response indicating a permanent error. Server Response: (501 Bad sender address syntax**)
03/10/11 16:26:42   ME-E0036: [AC83949E463246DDBD022BBF355D4606.MAI] MAIL FROM command Failed.
03/10/11 16:26:42   ME-E0008: [AC83949E463246DDBD022BBF355D4606.MAI] Outbound, could not send the command to the server (error 10038).
03/10/11 16:26:42   ME-E0060: [AC83949E463246DDBD022BBF355D4606.MAI] - Message could not be delivered to target domain (hiddendomain2.com). Message returned to Sender.
03/10/11 16:26:43   ME-I0119: Domain [hiddendomain1.com] has used local loopback address [127.0.0.1] because it is hosted locally.
03/10/11 16:26:43   ME-I0026: [AC83949E463246DDBD022BBF355D4606.MAI] Sending message
03/10/11 16:26:43   ME-I0102: [572] Address ([SMTP:<noreply@hiddendomain1.com]) is to be delivered to Catch-All address.
03/10/11 16:26:43   ME-I0149: [572] CAEFBF802B8646DB99B4D2401571AE3E.MAI was received successfully and delivery thread was initiated
03/10/11 16:26:43   ME-I0049: [AC83949E463246DDBD022BBF355D4606.MAI] Send Completed Successfully
03/10/11 16:26:43   ME-I0074: [572] (Debug) End of conversation
03/10/11 16:26:43   ME-I0132: Catch-All Message rendered for CAEFBF802B8646DB99B4D2401571AE3E.MAI

看來該錯誤已在此處報告,但已被SMTP服務器視為問題而避免,但似乎該問題確實與CI庫存在兼容性問題: http : //codeigniter.com/forums/viewthread/114030/

我非常確定這是CI的問題,因為PHP郵件可以正常工作。 誰能確認? 因為如果沒有的話,我需要更改用於CI的腳本。 我可以提供任何日志/詳細信息

我曾經遇到過同樣的問題,我在代碼中做了以下更改:

$config['protocol'] = 'smtp';
$config['validate'] = 'FALSE';

希望對你有用

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM