邮件发送

设定

Laravel 利用一个热门的函数库 SwiftMailer 来建立一个干净简单的 API。邮件配置文件为 app/config/mail.php,里面有些选项可以让您更改您的 SMTP 连接地址、凭证以及全局的寄件者 from。您可以使用任何的 SMTP 服务器。如果您想要使用 PHP 内建的 mail 函数来发送邮件,您可以将配置文件中的 driver 改为 mail 即可。sendmail 的驱动一样可以使用。

第三方邮件服务 API 驱动

Laravel 也包含了 Mailgun 和 Mandrill 服务的 HTTP API 的驱动方式。这些 API 比使用 SMTP 服务器更简单快速。这些驱动都需要在您的应用程序里预先安装 Guzzle 4 HTTP 函数库。您可以通过在您的 composer.json 文件中增加一行如下,来将 Guzzle 4 安装到您的项目中:

"guzzlehttp/guzzle": "~4.0"

Mailgun 驱动

使用 Mailgun 驱动前,先在 app/config/mail.php 配置文件中将 driver 设定为 mailgun。再来,如果您的项目中没有 app/config/services.php 请先建立他。并确定它包含了如下的内容:

'mailgun' => array(
    'domain' => 'your-mailgun-domain',
    'secret' => 'your-mailgun-key',
),

Mandrill 驱动

To use the Mandrill driver, set the driver option to mandrill in your app/config/mail.php configuration file. Next, create an app/config/services.php configuration file if one does not already exist for your project. Verify that it contains the following options:

'mandrill' => array(
    'secret' => 'your-mandrill-key',
),

Log 驱动

如果您的 app/config/mail.php 配置文件的 driver 被设定为 log 时,所有的邮件将会被写进日志中,且并不会真的被寄出。这主要用在快速本地除错和内容验证上。

基本用法

Mail::send 方法是用来发送电子邮件:

Mail::send('emails.welcome', array('key' => 'value'), function($message)
{
    $message->to('foo@example.com', 'John Smith')->subject('Welcome!');
});

send 方法的第一个参数为邮件内容的视图名称。第二个参数 $data 为传递至视图的变量,一般是以联合数组的形式出现,所有数据项都可以在视图中通过 $key 引用。而第三个参数为一个闭包让您可以指定更多发送电子邮件的信息选项。

注意: 变量默认被传递进邮件的视图中,且允许内嵌键值数组。所以最好避免传递名为 message 的变量到您的视图中造成冲突。

除了使用 HTML 视图外,您也可以指定一个纯文字的视图:

Mail::send(array('html.view', 'text.view'), $data, $callback);

或者您也可以指定视图类为 htmltext

Mail::send(array('text' => 'view'), $data, $callback);

您也可以为电子邮件信息指定其他选项如附加文件或是任何的副本收件者:

Mail::send('emails.welcome', $data, function($message)
{
    $message->from('us@example.com', 'Laravel');

    $message->to('foo@example.com')->cc('bar@example.com');

    $message->attach($pathToFile);
});

当附加文件到一个电子邮件中时,您也可以指定一个 MIME type 及/或 一个显示名称:

$message->attach($pathToFile, array('as' => $display, 'mime' => $mime));

注意:Mail::send 的闭包中使用 SwiftMailer 的 message 扩充实例,允许您可以调用任何类中的方法来建立您的电子邮件。

内嵌附件

内嵌图片到邮件中通常是一件很麻烦的事,然而Laravel 提供一个便利的方式让您内嵌图片到您的电子邮件当中且接收相对应的 CID。

内嵌图片到电子邮件的视图中

<body>
    Here is an image:

    <img src="<?php echo $message->embed($pathToFile); ?>">
</body>

内嵌数据到电子邮件的视图中

<body>
    Here is an image from raw data:

    <img src="<?php echo $message->embedData($data, $name); ?>">
</body>

注意 $message 这个变量一定会被 Mail 类传递到电子邮件的视图当中。

邮件队列

加入一个邮件到队列中

发送电子邮件会大幅的延长您应用程序的反应时间,许多开发者选择让电子邮件放进队列中,并在后台(非即时)发送。Laravel 使用内建的 unified queue API 让您可以方便的将要发送的电子邮件加入到队列之中,只要使用 Mail 类的 queue 方法:

Mail::queue('emails.welcome', $data, function($message)
{
    $message->to('foo@example.com', 'John Smith')->subject('Welcome!');
});

您也可以通过使用 later 方法来指定发送电子邮件的延迟秒数:

Mail::later(5, 'emails.welcome', $data, function($message)
{
    $message->to('foo@example.com', 'John Smith')->subject('Welcome!');
});

假如您想要指定一个特别的队列或管道来发送邮件,您可以使用 queueOnlaterOn 方法:

Mail::queueOn('queue-name', 'emails.welcome', $data, function($message)
{
    $message->to('foo@example.com', 'John Smith')->subject('Welcome!');
});

邮件与本地开发

在开发应用程序的寄信功能时,通常会希望在本地或是开发环境中关闭发送功能。您可以调用 Mail::pretend 方法,或是在 app/config/mail.php 配置文件的 pretendtrue 可以达到。当在 pretend 模式开启下,邮件将会被写到您的应用程序日志中取代实际寄出信件。

开启 "Pretend" 发送模式

Mail::pretend();