【问题标题】:Laravel 4.2. Send email, remote SMTP, Windows Server R2, IIS拉拉维尔 4.2。发送电子邮件、远程 SMTP、Windows Server R2、IIS
【发布时间】:2015-06-08 14:37:48
【问题描述】:

我刚刚移动了我的 Laravel 4.2。应用程序从 WAMP 到 IIS Web 服务器,电子邮件功能刚刚停止工作 - 不知道为什么。

我使用托管服务的外部 SMTP 服务器,所以我不认为它会导致任何问题。

我的设置:

return array(

/*
|--------------------------------------------------------------------------
| Mail Driver
|--------------------------------------------------------------------------
|
| Laravel supports both SMTP and PHP's "mail" function as drivers for the
| sending of e-mail. You may specify which one you're using throughout
| your application here. By default, Laravel is setup for SMTP mail.
|
| Supported: "smtp", "mail", "sendmail", "mailgun", "mandrill", "log"
|
*/

'driver' => 'smtp',

/*
|--------------------------------------------------------------------------
| SMTP Host Address
|--------------------------------------------------------------------------
|
| Here you may provide the host address of the SMTP server used by your
| applications. A default option is provided that is compatible with
| the Mailgun mail service which will provide reliable deliveries.
|
*/

'host' => 'smtp.*my-host*.se',

/*
|--------------------------------------------------------------------------
| SMTP Host Port
|--------------------------------------------------------------------------
|
| This is the SMTP port used by your application to deliver e-mails to
| users of the application. Like the host we have set this value to
| stay compatible with the Mailgun e-mail application by default.
|
*/

'port' => 587,

/*
|--------------------------------------------------------------------------
| Global "From" Address
|--------------------------------------------------------------------------
|
| You may wish for all e-mails sent by your application to be sent from
| the same address. Here, you may specify a name and address that is
| used globally for all e-mails that are sent by your application.
|
*/

'from' => array('address' => "example@mail.com", 'name' => "Example name"),

/*
|--------------------------------------------------------------------------
| E-Mail Encryption Protocol
|--------------------------------------------------------------------------
|
| Here you may specify the encryption protocol that should be used when
| the application send e-mail messages. A sensible default using the
| transport layer security protocol should provide great security.
|
*/

'encryption' => 'tls',

/*
|--------------------------------------------------------------------------
| SMTP Server Username
|--------------------------------------------------------------------------
|
| If your SMTP server requires a username for authentication, you should
| set it here. This will get used to authenticate with your server on
| connection. You may also set the "password" value below this one.
|
*/

'username' => "user@host.se",

/*
|--------------------------------------------------------------------------
| SMTP Server Password
|--------------------------------------------------------------------------
|
| Here you may set the password required by your SMTP server to send out
| messages from your application. This will be given to the server on
| connection so that the application will be able to send messages.
|
*/

'password' => "********",

/*
|--------------------------------------------------------------------------
| Sendmail System Path
|--------------------------------------------------------------------------
|
| When using the "sendmail" driver to send e-mails, we will need to know
| the path to where Sendmail lives on this server. A default path has
| been provided here, which will work well on most of your systems.
|
*/

'sendmail' => '/usr/sbin/sendmail -bs',

/*
|--------------------------------------------------------------------------
| Mail "Pretend"
|--------------------------------------------------------------------------
|
| When this option is enabled, e-mail will not actually be sent over the
| web and will instead be written to your application's logs files so
| you may inspect the message. This is great for local development.
|
*/

'pretend' => false,

我更改了上面的 auth 属性。

我从 Laravel 得到的错误。

{"error":{"type":"ErrorException","message":"stream_socket_enable_crypto(): Peer certificate CN=`*.my-host-name.se' did not match expected CN=`smtp.my-host.se'","file":"D:\\Dir1\\Dir2\\vendor\\swiftmailer\\swiftmailer\\lib\\classes\\Swift\\Transport\\StreamBuffer.php","line":95}}

有什么想法吗?我应该安装本地 SMTP 服务吗?

【问题讨论】:

    标签: email iis laravel-4 smtp windows-server


    【解决方案1】:

    您的服务器和 smtp 电子邮件服务器之间似乎存在 SSL 证书问题。

    我认为问题与此有关:https://github.com/swiftmailer/swiftmailer/issues/544

    这里有一个拉取请求,您可以尝试看看是否可以解决问题:https://github.com/swiftmailer/swiftmailer/issues/571

    【讨论】:

    • 谢谢! =) 此处从用户“if-joerch”复制:github.com/swiftmailer/swiftmailer/issues/544“如果您使用的是 PHP 5.6,由于 swiftmailer 中用于流上下文的“SSL 上下文选项”确实会发生错误。在 PHP 5.6 verify_peer 和 verify_peer_name默认设置为 TRUE,因此 PHP 检查 SSL 证书。您可以通过修改 StreamBuffer.php 中的函数“_establishSocketConnection”来禁用 SSL 检查。在 stream_socket_client 命令之前添加这些行:$options['ssl']['verify_peer' ] = FALSE; $options['ssl']['verify_peer_name'] = FALSE;"
    • 我在使用 Laravel Lumen 框架时遇到了同样的问题。刚刚添加了 Tibbelit 告知的这两行,它就像一个魅力!
    猜你喜欢
    • 1970-01-01
    • 2016-03-30
    • 2011-07-30
    • 1970-01-01
    • 1970-01-01
    • 2015-01-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多