郵件

設定

Laravel 基於熱門的 SwiftMailer 函式庫之上,提供了一個簡潔的 API。郵件設定檔為 config/mail.php,包含若干選項,讓您可以更改 SMTP 主機、連接埠、遤證,也可以讓您對函式庫傳送出去的所有訊息設定全域的 from 地址。您可使用任何您想要的 SMTP 伺服器。如果想使用 PHP mail 函式來寄送郵件,您可以將設定檔中的 driver 更改為 mail。您也可以使用 sendmail 驅動器。

API 驅動

Laravel 也包含了 Mailgun 及 Mandrill HTTP API 的驅動。這些 API 通常比 SMTP 伺服器更簡單快速。這兩套驅動都需要在應用程式中安裝 Guzzle 5 HTTP 函式庫。您可在 composer.josn 中加入下列程式碼, 以便在專案中加入 Guzzle 5:

"guzzlehttp/guzzle": "~5.0"

Mailgun 驅動

要使用 Mailgun 驅動,請將 config/mail.php 設定檔中的 driver 選項設定為 mailgun。接下來,若 config/service.php 設定檔還不存在於您的專案中,請建立此檔,並確認其包含下列選項:

'mailgun' => [
    'domain' => 'your-mailgun-domain',
    'secret' => 'your-mailgun-key',
],

Mandrill 驅動

要使用 Mandrill 驅動,將 config/mail.php 設定檔中的 driver 選項設定為 mandrill。接下來,若 config/service.php 設定檔還不存在於您的專案中,請建立此檔,並確認其包含下列選項:

'mandrill' => [
    'secret' => 'your-mandrill-key',
],

日誌驅動

若您的 config/mail.php 設定檔中的 driver 選項設定為 log ,所有的電子郵件都會被寫入日誌檔,而不會真正寄給任何收件者。這主要用於快速的本地端除錯及內容驗證。

基本用法

您可使用 Mail::send 方法來寄送電子郵件訊息:

Mail::send('emails.welcome', ['key' => 'value'], function($message)
{
    $message->to('[email protected]', 'John Smith')->subject('Welcome!');
});

傳入 send 方法的第一個參數為郵件視圖的名稱。第二個是傳遞給該視圖的資料,通常是一個關聯式陣列,讓視圖可透過 $key 來取得資料項目。第三個參數是一個閉包,可以對 message 進行各種設定。

注意: $message 變數總是會被傳入郵件視圖中,並且允許內嵌附件。因此最好避免在您的視圖本體中傳入 message 變數。

除了 HTML 視圖外,您也可以指定使用純文字視圖:

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

或者,您可使用 htmltext 作為鍵值來指定單一類型的視圖:

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

您也可以在郵件訊息中指定其他選項,例如副本收件者或附件:

Mail::send('emails.welcome', $data, function($message)
{
    $message->from('[email protected]', 'Laravel');

    $message->to('[email protected]')->cc('[email protected]');

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

要附加檔案至 message 時,可以指定 MIME 的類型、顯示名稱:

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

若您只需寄送一個簡單的字串而非完整的視圖,可使用 raw 方法:

Mail::raw('Text to e-mail', function($message)
{
    $message->from('[email protected]', 'Laravel');

    $message->to('[email protected]')->cc('[email protected]');
});

注意: 傳遞至 Mail::send 閉包的 message 實例是繼承了 SwiftMailer 的 message 類別,你可以呼叫該類別的任何方法來建立電子郵件訊息。

內嵌附件

在電子郵件中嵌入內部圖像通常很麻煩;然而 Laravel 提供一個便利的方法讓您對電子郵件附加圖像,並取得相應的 CID。

在郵件視圖中嵌入圖像

<body>
    這是一張圖像:

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

在郵件視圖中嵌入原始資料

<body>
    這是一張從原始資料來的圖像:

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

請注意 Mail 類別總是會將 $message 變數傳遞給電子郵件視圖。

郵件隊列

將郵件訊息加入隊列

寄送電子郵件訊息會大幅延長應用程式的回應時間,因此許多開發者選擇將郵件訊息加入隊列並於背景發送。 Laravel 使用內建 統一的 queue API ,讓您輕鬆地完成此工作。要將郵件訊息加入隊列,只要使用 Mail 類別的 queue 方法:

Mail::queue('emails.welcome', $data, function($message)
{
    $message->to('[email protected]', 'John Smith')->subject('Welcome!');
});

您也可以使用 later 方法來指定您希望延遲寄送郵件訊息的秒數:

Mail::later(5, 'emails.welcome', $data, function($message)
{
    $message->to('[email protected]', 'John Smith')->subject('Welcome!');
});

若您想要指定特定的隊列或「管道」來加入訊息,您可使用 queueOn 以及 laterOn 方法:

Mail::queueOn('queue-name', 'emails.welcome', $data, function($message)
{
    $message->to('[email protected]', 'John Smith')->subject('Welcome!');
});

郵件與本地端開發

當開發寄送電子郵件的應用程式時,我們通常希望不要真的從本地端或開發環境寄出郵件。您可以使用 Mail::pretend 方法或將 config/mail.php 設定檔中的 pretend 選項設定為 true。在 pretend 模式下,訊息會改而寫入應用程式的日誌檔,而不會真的寄出給收件者。

若您想要實際閱覽測試的郵件,可考慮使用像是 MailTrap 的服務。