目的
- htmlメールとtextメールをどちらか一つ、または両方を送信する方法をまとめる
条件
- 下記のどちらかの記事の内容の実装が完了していることを確認する。筆者は「laravel6 ファイル添付できるメール送信機能を作成する」のあとに本記事で紹介している作業を実施した。
情報
- 筆者はMacに直接作成したlaravelのローカル開発環境で本記事に記載したソースの検証を行っている。
- 筆者の環境ではメールの受信確認はMailCatcherを用いて行う。
- メール送信相手のアドレスは「test@example」とする。
- メール送信者のアドレスは「app@example」とする。
- 特筆しない限り実行しているコマンドは前のコマンドと同じディレクトリで実行するものとする。
- 下記の記事で実装したメールをhtmlメールとtextメール両方送信するように修正する。
概要
- コントローラファイルの修正
- メールクラスの修正
- htmlメールのテンプレート追加
- 確認
詳細
-
コントローラファイルの修正
-
NoticeController.phpを開き、下記のように修正する。
アプリ名ディレクトリ/app/Http/Controllers/NoticeController.php<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use App\Http\Requests\MailRequest; use Illuminate\Support\Facades\Mail; use App\Mail\AppMail; use App\Services\MailAttachmentService; class NoticeController extends Controller { /** * @var MailAttachmentService */ private $mailAttachmentService; public function __construct(MailAttachmentService $mailAttachmentService) { $this->mailAttachmentService = $mailAttachmentService; } public function index() { return view('notices.index'); } public function mailMake() { return view('notices.mails.make'); } public function mailConfirm(MailRequest $mailRequest) { $postData = $mailRequest->all(); if (isset($postData['file'])) { $postData['putFileInfo'] = $this->mailAttachmentService->saveFile($postData['file']); } $viewData = [ 'postData' => $postData ]; return view('notices.mails.confirm', ['viewData' => $viewData]); } public function mailSend(Request $request) { // 下記を追記 $mailInfo = [ 'htmlTemplate' => 'mail_templates.html_mail', 'textTemplate' => 'mail_templates.text_mail', ]; // 上記までを追記 $postData = $request->all(); // 下記を修正 Mail::to('test@example')->send(new AppMail($postData, $mailInfo)); return redirect(route('notice.index')); } }
-
-
メールクラスの修正
-
AppMail.phpを開き、下記のように修正する。
アプリ名ディレクトリ/app/Mail/AppMail.php<?php namespace App\Mail; use Illuminate\Bus\Queueable; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Mail\Mailable; use Illuminate\Queue\SerializesModels; class AppMail extends Mailable { use Queueable, SerializesModels; /** * メール送信引数 * * @var array */ private $postData; /** * Create a new message instance. * * @return void */ // 下記を修正 public function __construct($postData, $mailInfo) { $this->postData = $postData; // 下記を修正 $this->mailInfo = $mailInfo; } /** * Build the message. * * @return $this */ public function build() { // 下記を修正 // デフォルト処理、fromメールアドレス、件名、テキストメールのテンプレートの設定 $mail = $this->from('app@example')->subject($this->postData['subject'])->text($this->mailInfo['textTemplate'], ['postData' => $this->postData]); if (isset($this->postData['filePath'])) { // 添付ファイルが有るときに実行 $mail->attachFromStorage($this->postData['filePath'], mb_encode_mimeheader($this->postData['fileName'])); } if (isset($this->mailInfo['htmlTemplate'])) { // htmlメールも同時に送信するとき $mail->view($this->mailInfo['htmlTemplate'], ['postData' => $this->postData]); } return $mail; // 上記までを修正する。 } }
-
-
htmlメールのテンプレート追加
-
下記コマンドを実行してhtmlメールのテンプレートを作成して開く。
$ vi resources/views/mail_templates/html_mail.blade.php
-
開いたファイルに下記の内容を記載する。
アプリ名ディレクトリ/resources/views/mail_templates/html_mail.blade.php{!! nl2br(e($postData['content'])) !!} <h1>Foo</h1>
-
-
確認
-
下記コマンドを実行してローカルサーバを起動する。
$ php artisan serve
-
下記にアクセスする。
-
件名と内容に任意の内容を入力して「確認」をクリックする。遷移先のページで「送信」をクリックしてメールを送信する。
-
受信したメールを確認する。
-
MailCatcherで確認する場合「HTML」のタブを開いたときにメール内容の末尾にh1要素で「Foo」と表示されることを確認する。
-
「Plain Text」のタブを開いたときメールの内容がそのまま表示されることを確認する。
-