言及&リンク御礼

2008/08/08 未分類 spok
◎設置が簡単。
◎viewに本文を入れられる。
◎コントローラーがスッキリする。
◎文面は elements フォルダにがんがん作れるので送信する内容が多くても管理しやすい。
qdmailの使い方-秀ブログ
ググれば解決法はいくらでも見つかるんですが、
この時期にあえてちゃんとライブラリとしてだす所がいいですね。
cakePHP メール送信はもうこれでいいでしょ -LoveIT - 安江ブログ
いつか確実に使う機会がありそうなんでめもめも
PHPでデコメール Qdmail-LoveIT - 安江ブログ
デコメールは各キャリアによって仕様が異なっているため、送信・変換が簡単にできるのは嬉しいですね。
全キャリア対応のデコメールの作成・変換が行えるPHPライブラリQdmail  ke-tai.org

CAP-LABテクニカルさんのCakePHP高機能メールコンポーネント-Qdmail オススメ
国ごとにCakePHPを含めたフレームワークの検索キーワードランキングを調べてみた-ねねとまつの小部屋
CakePHP でメールを送信する機能は色々な方が作成されていますが、今回は Qdmail を利用してみました。
Qdmailで日本語のメール送信-CakePHPクッキング
なんの問題もなく、快適に動作しました。
すばらしかー。
CakePHPで日本語メールの送信-"42"
使ってみたらと言われたのが Qdmail
メール送信ライブラリ Qdmail-PodTV開発日誌(symfony風味)
結構簡単に実装できますた。
CakePHP :「Qdmail」コンポーネントで送信されたメール内容が変-yahoo!ブログからの移民
Qdmailなるものを発見。
これは使えそう。
Qdmail-Am I Wry? No
なんてったって、PHP4に対応してんのが、本当にありがたい。
CakePHPその17 ~Qdmail Component~sandmanの旅行の写真”とか”

デコメール

2008/08/02 未分類 spok
ここはバージョン1系のeasyモードの解説です。バージョン0系については、バージョン0系のeasyモードの使い方をご参照ください。

ここでは、日本の携帯端末特有のデコメの送り方について説明します。

前提として、テキストメールHTMLメールの送り方は、知っておいて下さい。

基本的な送り方

例を示します。
$mail = & new Qdmail();

$body = '<html><body bgcolor="#aabbff">
<h1>HTMLメールテスト</h1>
<b>太字</b>
<font color="red">文字色を変えてみます。</font>
<div>画像はこのように</div>
<img src="cid:test2.jpg">
<div>文章中に置くことができます。</div>
<p>Send by Qdmail</p>
<div>携帯端末、キャリアによって使えるHTMLタグが違いますので注意してください。</div>
<div><a href="mailto:address@example.com">メールはこちらへ</a></div>
<div><a href="tel:00-0000-0000">電話はこちらへ</a></div>
</body></html>';


$mail -> easyDeco(
      array('address@exaple.com' ,'宛先(日本語OK)' ),
      'デコメのテスト' ,
      $body,
      array( 'from@example.com' ,'配信元(日本語OK)'),
      'test2.jpg'
 );
PHP5の場合は、new の前の"&"は必要ありません。
test2.jpgという名前の、適当な画像ファイルを、貴方のほうで準備しておいてください。もちろん、ファイル名はアルファベットと数字であれば、なんでも構いません。(cid:との連携は必要)

インテリジェント・デコメ・システム

通信キャリア(ドコモ、au、ソフトバンクモバイル、イーモバイル)は、それぞれデコメの仕様が異なりますが、Qdmailは、その違いを吸収して、@以下のアドレスで、キャリアを判別し、それぞれに適した形にHTMLメールを加工して、メールを送ります。

ただし、端末毎の違いをすべて検証すたわけではありません。場合によっては、表示が崩れることもあるかも知れません。
その際は情報をお寄せいただければ、幸いです。
技術的参考記事:CPA-LABテクニカル-デコメール携帯4社MIMEマルチパート比較

キャリアをごちゃまぜにして、一度に送る

ちょっと複雑にみえますが、テキストメールの送り方を理解していれば簡単です。
test2.jpgとtest3.jpgという名前の画像ファイルを適当に用意してください。
$mail = & new Qdmail();

$to[] = array('××××××@docomo.ne.jp','ドコモ端末さん');
$to[] = array('××××××@ezweb.ne.jp','au端末さん');
$to[] = array('××××××@softbank.ne.jp','ソフトバンク端末さん');
$to[] = array('××××××@emnet.ne.jp','イーモバイル端末さん');

$body = '<html><body bgcolor="#aabbff">
<h1>HTMLメールテスト</h1>
<b>太字</b>
<font color="red">文字色を変えてみます。</font>
<div>画像はこのように</div>
<img src="cid:test2.jpg">
<div>文章中に置くことができます。</div>
<p>Send by Qdmail</p>
<img src="cid:test3.jpg">
<div>携帯端末、キャリアによって使えるHTMLタグが違いますので注意してください。</div>
<div><a href="mailto:address@example.com">メールはこちらへ</a></div>
<div><a href="tel:00-0000-0000">電話はこちらへ</a></div>
</body></html>';

$attach = array('test2.jpg','test3.jpg');

$mail -> easyDeco(
      $to ,
      'デコメのテスト' ,
      $body,
      array( 'from@example.com' , '配信元(日本語OK)'),
      $attach
 );
コツtips
  1. 画像のリンクは、”cid:ファイル名”とし、ファイル名を同じにします。これはコンテンツIDといいますが、別途指定することもできます。デフォルトは、ファイル名です。
  2. easyDecoモードでは、複数の宛先を指定しても、それをQdmailがひとつづつに分解し、1通ごとにメールを送付します。(そうしないこともできます。)
  3. 使える画像の種類、容量はキャリアによって異なりますが、携帯端末にはごく小さなファイルしか送れないと理解しておいたほうがいいでしょう。詳細は各キャリアの仕様をみてください。

htmlメール

2008/08/02 未分類 spok
ここはバージョン1系のeasyモードの解説です。バージョン0系については、バージョン0系のeasyモードの使い方をご参照ください。

メールアドレスの指定の基本

メールアドレスだけの場合'address@example.com'
表示名もつける場合array( 'address@example.com' , '表示名' )
表示名をつけて、複数指定array(array( 'address@example.com' , '表示名' ),array( 'address@example.com' , '表示名' ).....)
メールアドレスだけの複数指定array(array( 'address@example.com'),array( 'address@example.com')...

htmlメール

ここで説明するのは、画像をインターネットに置いておくタイプのHTMLメールです。
HTML内に表示する画像もいっしょに送るタイプは、「インラインHTMLメール」といい、別項にて説明します。デコメは、インラインHTMLメールであり、日本の携帯端末向けのデコレーションメールは、別に説明します。
require_once('qdmail.php');
$mail = & new Qdmail();*1

$mail -> easyHtml(
      array8 'mailto@example.com' , '宛先(日本語OK)' ),
      'タイトル(日本語OK)' ,
      '本文(日本語OK)',
      array( 'from@example.com' , '配信元(日本語OK)' )
 );
Htmlの部分が変わった以外は、easyText と全く同じです。
添付ファイルやその他のヘッダーの設定の仕方も同じです。
もちろん、'本文(日本語OK)'の部分には、htmlで内容を書かなくてはなりません。
Qdmailでは、htmlメールを解析することができないメーラーや、ポリシーとしてhtmlメールを読まない方にも、内容だけは届くように、htmlメールから、代替テキストを自動的に生成して、メールに添えています。
このオプションは変更することもできます。

HTMLメールの例

ここでは、簡単なhtmlメールの内容の例を書いておきます。
$body = '<html><body bgcolor="#aabbff"><h1>HTMLメールテスト</h1><b>太字</b><font color="red">文字色を変えてみます。</font><p>Send by Qdmail</p><div><a href="mailto:address@example.com">メールはこちらへ</a></div></body></html>';
$mail -> easyHtml(
      array('address@example.com' , '宛先(日本語OK)') ,
      'タイトル(日本語OK)' ,
      $body,
      array('from@example.com' ,'配信元(日本語OK)')
 );
このHTMLは古い書き方ですが、わかりやすいのであえて、古い方法で書きました。

*1 : PHP5では、"&"は必要ありません。

easy型の使い方(ver1系)

2008/08/02 未分類 spok
バージョン0系と1系では、easyモードの使い方が異なります。
バージョン0系については、バージョン0系のeasyモードの使い方をご参照ください。

easyモードの使い方(バージョン1系)

easyモードは、オブジェクト指向型でなるべく簡単に、様々なメールを送信できるよう工夫したライブラリです。

特徴

全くオブジェクト指向型を抜きにしての指定はできませんが、オブジェクト指向独特の「->」演算子をなるべく使わずに、通常の関数のように使うのが特徴です。
一方で、e-mailは設定項目が多いので、関数の引数の数は多くなり、場合によっては多次元配列を使わなくてはならない場合もあります。


目次

  • easyText_ver1
    簡単テキストメール - 文字化けなしのテキストメールの送付。添付ファイル日本語名も簡単。
  • easyHtml_ver1
    簡単HTMLメール - easyTextのHTMLメール版。自動代替テキスト生成機能付き。
  • easyReplace_ver1 そのうちマニュアル化します。。。。
    簡単テンプレート - 名前、メールアドレスの他、送付先に適合したメッセージやIDを送る機能
  • easyDeco_ver1
    簡単デコメール - 日本の携帯端末向けデコレーションメールの送付
  • easyDecoRep
    簡単デコメール+簡単テンプレート

テキストメール

2008/08/02 未分類 spok
ここはバージョン1系のeasyモードの解説です。バージョン0系については、バージョン0系のeasyモードの使い方をご参照ください。

単純なテキストメール

推奨文字コード

Qdmailは、ソースコードや渡された文字コードを自動的に判別し、もっとも文字化けの少ない方法で送るように試みます。
しかし、インターネットメールの環境は様々であり、自動判別は完璧なものではありません。
もっとも文字化けが出る可能性が低いのは、当方の開発環境と同じ以下の環境です。
スクリプトの文字コード:UTF-8で統一。
スクリプトの改行コード:CRLF
デフォルトでは、Qdmailは、このUTF-8を日本語のメールに適したiso-2022-jpに変換して送ります。
もちろん、EUC-JP,SHIFT-JISでも、改行コードLFのみでも大丈夫なようには設計してあります。

メールアドレスの指定の基本

メールアドレスだけの場合'address@example.com'
表示名もつける場合array( 'address@example.com' , '表示名' )
表示名をつけて、複数指定array(array( 'address@example.com' , '表示名' ),array( 'address@example.com' , '表示名' ).....)
メールアドレスだけの複数指定array(array( 'address@example.com'),array( 'address@example.com')...

一番簡単なメール

インクルードできるパスの通ったところに、qdmail.phpを配置してください。
わからなければ、呼び出すファイルと同じディレクトリ(フォルダ)で構わないです。
require_once('qdmail.php');
$mail = & new Qdmail();
$mail -> easyText(
      array( 'mailto@example.com' , '宛先(日本語OK)' ),
      'タイトル(日本語OK)' ,
      '本文(日本語OK)',
      array('from@example.com' , '配信元(日本語OK)')
 );
(PHP5の時は、new 前の "&" は必要ありません。)

オブジェクト指向(OOP)的な書き方がわからない方は、-> や new の意味がわからないかも知れませんが、おまじないと思って、上記をコピー&ペーストしてみてください。
「$mail -> 関数名()」で、ひとつの関数と思って構いません。
なお、「$mail -> & new Qdmail();*1」は、最初に一回だけやっておけば、それ以降は必要ありません。
「$mail」は、自分の好きな変数名にして構いません。以後は、その「newした変数名->関数名」に置き換えて下さい。

添付ファイルを添付する

添付ファイルの置き場所:まずは、呼びだしもとのファイルと同じ場所において試してみて下さい。このファイルの置き場所は変更することもできます。
$mail = & new Qdmail();();*1
$mail -> easyText(
       array( 'mailto@example.com' , '宛先(日本語OK)' ),
       'タイトル(日本語OK)' ,
       '本文(日本語OK)',
       array( 'from@example.com' , '配信元(日本語OK)' ), 
       array( 'test.jpg', '添付された時のファイル名(日本語OK).jpg')
 );
なお、添付ファイルの置き場所は、呼びだしもとファイルからの相対パスでも、絶対パスでも指定できます。
例えば、
相対パス「./images/test.jpg」「images/test.jpg」
絶対パス「/home/hogehoge/images/test.jpg」「c:\htdocs\hogehoge\test.jpg」
最初の文字が「/」「¥」「\」の場合は、絶対パスとして解釈しますので注意してください。

複数のファイルを添付する。

これ以降は、$mail = & new Qdmail(); は省略します。

$param[] = array( 'test.jpg' , '添付ファイル名(日本語OK省略も可能).jpg' );
$param[] = array( 'test2.jpg' , '添付ファイル名2(日本語OK省略も可能).jpg' );

$mail -> easyText(
       array( 'mailto@example.com' , '宛先(日本語OK)' ),
       'タイトル(日本語OK)' ,
       '本文(日本語OK)',
       array( 'from@example.com' , '配信元(日本語OK)' ), 
       $param
 );

複数の宛先に送付する

この例では、2人に送っていますが、何人でも追加できます。
toヘッダに複数指定した場合は、その指定された人全員が、全員のメールアドレスを知ることになりますので注意しましょう。
それがまずい場合(ネットサービスでは、ほとんどがそうですよね)は、後で述べるBCCを使いましょう。

複数の宛先に送付する

複数の宛先に送付する (表示名も指定)


$to[] = array('mailto1@example.com' , '表示名1(日本語OK)' );
$to[] = array('mailto2@example.com' , '表示名2(日本語OK)' );

$mail -> easyText(
        $to ,
       'タイトル(日本語OK)' ,
       '本文(日本語OK)',
       array('from@example.com' , '配信元(日本語OK)' ) 
 );
必ず、メールアドレスのキーがゼロ、表示名のキーが1になるようにします。

cc や bcc も追加する。


$address['to'][] = array('mailto1@example.com' , '表示名1(日本語OK)' );
$address['to'][] = array('mailto2@example.com' , '表示名2(日本語OK)' );

$other_heder['cc'][] = array('mailto3@example.com' , '表示名3(日本語OK)' );
$other_heder['cc'][] = array('mailto4@example.com' , '表示名4(日本語OK)' );

$other_heder['bcc'][] = array('mailto5@example.com' , '表示名5(日本語OK)' );
$other_heder['bcc'][] = array('mailto6@example.com' , '表示名6(日本語OK)' );

$other_heder['from'][] = array('from@example.com' , '配信元(日本語OK)' );

$mail -> easyText(
        $address ,
       'タイトル(日本語OK)' ,
       '本文(日本語OK)',
       $other_header
 );
toやccは大文字でも小文字でも問題ありません。
ccやbccは省略可能ですが、toには最低1つの宛先が必要になりますので、注意して下さい。
Fromを指定していた引数の部分が、other_headerに置き換わります。その代わりに、$other_headerの中に、fromを指定しておきます。Fromヘッダーは必須ヘッダーです。

reply-toを設定する

WEBサービスでは、Fromは配信専用にして、reply-toを設定したい場合もあるでしょう。

$var['from'] = array('mailto2@example.com' , '表示名2(日本語OK)');
$var['reply-to'] = array('mailto3@example.com' , '表示名3(日本語OK)');

$mail -> easyText(
       'address1@example.com' ,
       'タイトル(日本語OK)' ,
       '本文(日本語OK)',
       $var  
 );

*1 : PHP5の時は、new 前の "&" は必要ありません。