メール送信(qdmail)

CakePHP(+qdmail)でメール送信する処理を実装しました。

準備

2つのライブラリ(.php)をダウンロードし、以下のように配置して下さい。
app/controllers/components/qdmail.php
app/controllers/components/qdsmtp.php

qdmail - qdmail.1.2.6b.zip (執筆時のバージョン)
qdsmtp - qdsmtp.0.2.0a.zip (執筆時のバージョン)

PHPのSSLを有効化

php.ini内以下のパラメータを追加もしくはコメントをはずして下さい。これを行わないと「Unable to find the socket transport "ssl"」とエラーになります。

extension=php_openssl.dll

実装

1) Componentの読み込み/メール送信処理のパラメータを指定
(app/app_controller.php)
以下は、Gmailを送信クライアントとした例になります。

class AppController extends Controller {
    var $components = array(
        'Qdmail',                          // Qdmail
    );

    var $mail_param = array(
        'host' => 'ssl://smtp.gmail.com',  // SMTPサーバアドレス
        'port' => 465,                     // SMTPポート番号
        'from' => 'sender@gmail.com',      // 送信者アカウントのメールアドレス
        'protocol' => 'SMTP_AUTH',         // プロトコル/コマンド
        'user' => 'sender@gmail.com',      // Gmailのメールアドレス
        'pass' => 'password',              // メールアカウントのパスワード
    );
}

送信アカウントにGメールを使用する場合は以下の情報を参考
その他のメール クライアントの設定

2) メール送信処理
あとは、コントローラ内に関数を実装し、_sendfuncを任意の場所で呼び出して下さい。

// メール送信
function _sendfunc(){
    $this->Qdmail->smtp( true);
    $this->Qdmail->smtpServer( $this->mail_param);          // SMTPサーバのパラメータ
    $this->Qdmail->to( 'reciever@domain.com', 'reciever');  // 送信先メールアドレス
    $this->Qdmail->subject( 'Mail test');                   // メール件名(タイトル)
    $this->Qdmail->from( 'sender@gmail.com', 'Sender');     // 送信元メールアドレス
    $text = 'This is test mail';                            // メール本文
    $this->Qdmail->text( $text);
    $this->Qdmail->send();
}

また、

    $this->Qdmail->cc('cc@domain.com');                   // CC送信先
    $this->Qdmail->bcc('bcc@domain.com');                 // BCC送信先

を加えることでCC・BCC送信も可能です。

  • このエントリーをはてなブックマークに追加

関連記事

no image

Debugkitをインストール

CakePHPのデバッグツールとしてはデファクトスタンダードといってもいいDebugkitをインストールしました。 ダウンロード CakePHP 1.3用 https://github.com

CakePHP 1.3 インストール

使い古されている手ではありますが、表題の件とレンタルサーバへの配置方法などにも使えますので参考にしていただけたらと思います。 まずはレンタルサーバでCakePHPを動作させる CakePHPア

no image

ユーザ登録(仮登録・メール・本登録)

ここ最近は、メールアドレスだけでなく、SNSのアカウントと連携してユーザ登録することもできるWebサービスが増えてきましたね。ユーザは割合としてどちらを選んでるのか気になるところですが。私はできるだけ

no image

WYSIWYGエディタを実装

WYSIWYGエディタをCakePHPにいくつか試してみました。 CKEditor 実装 // head // View(~.ctp) 解凍してwebroot/jsフ

no image

Htmlヘルパー

ソース:\cake\libs\view\helpers\html.php charset / 文書の文字コードを設定する <?php echo $this->Html-

no image

シンプルに設置できる数字Captcha「MathCaptcha」

スパム防止などで利用されているCaptchaですが、数字版で使えるものがないか探してみました。 この「MathCapthca」は非常にシンプルに設置できるのはいいですが、やっぱりクエスチョンの部分は

no image

recursive設定によるfind()性能改善

CakePHPでは、モデルにアソシエーションを設定している場合、recursive(=>joinする階層)はデフォルトで0に設定されています。「recursiveゼロ」の意味するところとは、「1跨ぎま

Cookieログイン

今回は、「keep me logged in」などログイン画面でよくみかけるクッキーログインの機能を使ってみます。 CakePHPには、Cookieコンポーネントがあります。(PHPのsetcook

no image

Jsヘルパーを使用してAjax更新

更新処理でページ遷移を伴う場合、ページ全体をレスポンスするのに対して、Ajax処理ではページの一部のレスポンスが可能となるためサーバからの通信量を抑えることが可能となります。 Jsヘルパーを使用して

no image

独自のバリデーションルール

CakePHPで組み込みバリデーションをつくる方法は色々あります。 参考:Data Validation — CakePHP Cookbook v1.3 documentation 上記リンク内に

Comment

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

*

PAGE TOP ↑