CakeEmailでメール送信(@gmail)

CakePHP 2になって追加されたクラスCakeEmailがシンプルに使えます。これを使用してメール送信を行う処理を実装してみました。
CakeEmailクラスの読み込み
/app/Config/bootstrap.php(全体的に使用する場合)もしくは各々の(使用する)コントロールに定義します。
App::uses( 'CakeEmail', 'Network/Email');
CakeEmailの設定
database.phpと同様、/app/Config下に設定ファイルが用意されています(email.php.default)ので、email.phpにリネームして下さい。そこに使用するメールサーバの設定を行います。以下はGmailからの送信設定を追加しています。
// /app/Config/email.php class EmailConfig { public $default = array( .... ); // Gmailを例 public $gmail = array( 'host' => 'ssl://smtp.gmail.com', 'port' => 465, 'username' => 'username@gmail.com', // ユーザ名 'password' => 'password', // パスワード 'transport' => 'Smtp', 'tls' => true ); // さくらインターネットを例 public $sakura = array( 'host' => '______.sakura.ne.jp', // 初期ドメイン 'port' => 587, 'username' => 'username@______.sakura.ne.jp', // ユーザ名: // 初期ドメインのメールアドレスもしくは、独自ドメインのメールアドレス 'password' => 'password', // メールパスワード 'transport' => 'Smtp', ); }
送信処理(メール本文ベタ書き)
newでインスタンス化する際にそこで使用する設定を引数で渡します。('gmail')
$email = new CakeEmail( 'gmail'); // インスタンス化 $email->from( array( 'sender@domain.com' => 'Sender')); // 送信元 $email->to( 'reciever@domain.com'); // 送信先 $email->subject( 'メールタイトル'); // メールタイトル $email->send( 'メール本文'); // メール送信
送信処理(メール本文をテンプレート化)
$email = new CakeEmail( 'gmail'); // インスタンス化 $email->from( array( 'sender@domain.com' => 'Sender')); // 送信元 $email->to( 'reciever@domain.com'); // 送信先 $email->subject( 'メールタイトル'); // メールタイトル $email->emailFormat( 'text'); // フォーマット $email->template( 'templete'); // テンプレートファイル $email->viewVars( compact( 'var1', 'var2')); // テンプレートに渡す変数 $email->send(); // メール送信
- emailFormat
'html'もしくは'text'を選択します。
また、'both'と設定しtemplateをhtml・textと用意しておくとマルチパートメールを送信することも可能です。 - template
使用するテンプレートファイルを指定。emailFormatが
htmlの場合 => /app/View/Emails/html下
textの場合 => /app/View/Emails/text下
に、.ctpで配置 - viewVars
テンプレートに渡す変数を必要なだけcompactして、$var1などでアクセス
「This email was sent ~」
テンプレートを使用した際にメール本文末尾に付けられる"This email was sent using the CakePHP Framework, http://cakephp.org"を消すのは、/app/View/Layouts/Emails/text/default.ctp (もしくは、/app/View/Layouts/Emails/html/default.ctp)から
関連記事
-
-
Js/Cssファイルの読み込みや出力する方法
CakePHPのHTMLヘルパーにはjsファイルやcssファイルを読み込むためのメソッドが用意されています。ファイルを読み込むのに加えて、出力先を複数指定できるようになっています。 また、インライン
-
-
HttpSocketを使用してリクエスト送信
CakePHPには、Webサービスへのリクエスト送信のためのHttpSocketクラスが用意されています。 HttpSocket get HTTP GETリクエストを発行します。デモ H
-
-
radioボタンを実装
Radioボタンの実装は、セレクトボックスとほぼ同じです。 個人的にはラジオボタンをすすんで使用することは少ないのですが、2択くらいの選択肢であれば非常に便利ですよね。 今回は、その実装方法 デモ
-
-
複数ファイルアップロードフォーム
CakePHP 2.0からはHTML5が標準でサポートとなり、複数ファイルアップロードのためのフォーム記述が容易になりました。 View (ビュー) 配列 Array (
-
-
Cookieログイン
今回は、ログイン画面でよくみかけるクッキーログインの機能を使ってみます。 CakePHPには、Cookieコンポーネントがあります。(PHPのsetcookieメソッドのラッパー)メソッドはwr
-
-
Formヘルパーのinputタグのdiv/labelなどの設定
Formヘルパーのinputではデフォルトでは以下のようにdivで囲われて、labelが付与されて出力されます。 CSSのフレームワークなどであらかじめ決まったスタイルがある場合に便利に作られていま
-
-
バリデーション前後に処理を追加できる「beforeValidate」「afterValidate」
CakePHPでは、「beforeValidate」「afterValidate」というバリデーション処理の前後で追加の処理を実装できるコールバック関数が用意されています。 beforeVali
-
-
コントローラ内でバリデーション処理を呼び出す
CakePHPでは、saveメソッドの際にバリデーション処理も自動で行われますが、save処理と切り離してバリデーションを行うこともできます。このときは、save時と若干異なる処理体系になります。
-
-
DebugKitを導入
定番のブログチュートリアルをこなして、定番のDebugKitを導入してみました。 2.3からはCakePHPインストール直後に以下のように導入を推奨するような警告メッセージが表示されるようになりまし
-
-
入力文字列の長さ(文字数)をバリデーション
CakePHP 2には、コアバリデーションに文字列の長さを検証する関数が用意されています。 文字列長(コア)バリデーション minLength - 最小文字数以上であること maxLengt
Comment
[…] http://kwski.net/cakephp-2-x/1017/ […]
emailFormatはhtml,text,both: CakeEmailでメール送信(@gmail) https://t.co/2UKcI5cUNt
[…] CakePHP 2.x – CakeEmailでメール送信(@gmail) […]
“CakePHP 2.x: CakeEmailでメール送信(@gmail) | Think deeply, Do less, More effective” http://t.co/ys8sjMYbgh #cakephp #smtp
CakePHP 2.x: CakeEmailでメール送信(@gmail) | Think deeply, Do less, More effective - http://kwski.net/cakephp...
CakeEmailでメール送信(@gmail) http://kwski.net/cakephp-2-x/1017/ … @kwski3さんから