1

これで私の髪を引っ張ります。

この Cakephp (2.2) アプリをローカル マシンで開発したところ、問題なく smtp を使用して gmail 経由でメールを送信できました。それ以来、私はそれを 1and1 サーバーにデプロイしましたが、送信できなくなりました。さらにイライラするのは、ケーキから適切なデバッグ情報を取得できないように見えることです。

コードは次のとおりです。

if($fu['name']) {              

            $url = Router::url('/admin/', true );
            $ms = $url;
            $ms = wordwrap($ms,1000);

           //============Email================//
           // SMTP Options
           $this->Email->smtpOptions = array(
               'port'=>'465',
               'timeout'=>'30',
               'host' => 'ssl://smtp.gmail.com',
               'username'=>'myemail@gmail.com',
               'password'=>'password'
                 );
           $this->Email->template = 'newExpenseClaim';
           $this->Email->from    = 'Expense Tracker <myemail@email.co.uk>';
           $this->Email->to      = 'myemail@fakeemail.com'; 
           $this->Email->subject = 'New Expense Claim Submitted - Please Review';
           $this->Email->sendAs = 'both';

           $this->Email->delivery = 'smtp';

           // Set username & url in email
           $this->set('user', $fu['name']);
           $this->set('ms', $ms);
           //$this->Email->send();

           if(!$this->Email->send()) {
                CakeLog::write('debug', $this->Email->smtpError);
            }

           $this->set('smtp_errors', $this->Email->smtpError);

           //============EndEmail=============//   
        }

失敗するたびに次のデバッグ情報を取得します(画面に出力され、非常に迷惑なデバッグログには何も記録されません)。

    Connection refused

Error: An Internal Error Has Occurred.
Stack Trace

    CORE/Cake/Network/Email/SmtpTransport.php line 95 → CakeSocket->connect()
    CORE/Cake/Network/Email/SmtpTransport.php line 60 → SmtpTransport->_connect()
    CORE/Cake/Network/Email/CakeEmail.php line 1059 → SmtpTransport->send(CakeEmail)
    CORE/Cake/Controller/Component/EmailComponent.php line 345 → CakeEmail->send(null)
    APP/Controller/ExpenseClaimsController.php line 236 → EmailComponent->send()
    APP/Controller/ExpenseClaimsController.php line 278 → ExpenseClaimsController->notifyAdminsOfNewClaims()
    [internal function] → ExpenseClaimsController->add()
    CORE/Cake/Controller/Controller.php line 485 → ReflectionMethod->invokeArgs(ExpenseClaimsController, array)
    CORE/Cake/Routing/Dispatcher.php line 186 → Controller->invokeAction(CakeRequest)
    CORE/Cake/Routing/Dispatcher.php line 161 → Dispatcher->_invoke(ExpenseClaimsController, CakeRequest, CakeResponse)
    APP/webroot/index.php line 92 → Dispatcher->dispatch(CakeRequest, CakeResponse)

誰でも助けることができますか?前もって感謝します

** ラッパーとソケット情報で更新 **

これらは、これらの関数から返されるラッパーとソケットです。

ラッパー:

array(
    (int) 0 => 'https',
    (int) 1 => 'ftps',
    (int) 2 => 'compress.zlib',
    (int) 3 => 'compress.bzip2',
    (int) 4 => 'php',
    (int) 5 => 'file',
    (int) 6 => 'data',
    (int) 7 => 'http',
    (int) 8 => 'ftp',
    (int) 9 => 'zip'
)

ソケット

array(
    (int) 0 => 'tcp',
    (int) 1 => 'udp',
    (int) 2 => 'unix',
    (int) 3 => 'udg',
    (int) 4 => 'ssl',
    (int) 5 => 'sslv3',
    (int) 6 => 'sslv2',
    (int) 7 => 'tls'
)
4

1 に答える 1

1

最初に、ホスティングが発信接続をサポートするものを確認する必要があります。簡易チェックも同様

echo implode("", file("http://google.com"));

次に、どの PHP が SSL 接続をサポートしているか、SSL 用のストリーム ラッパーを持っているかを確認する必要があります。どうやったら確認できるのか思い出せません。しかし、キーワードでグーグルで検索してください:PHPストリームラッパーSSL

于 2012-11-23T16:29:19.200 に答える