SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

連載記事

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

CodeZine BOOKS(コードジン・ブックス)は、CodeZineの連載からカットアップした、開発現場の課題解決に役立つ書籍シリーズです。

書籍に関する記事を見る

'); googletag.cmd.push(function() { googletag.pubads().addEventListener('slotRenderEnded', function(e) { var ad_id = e.slot.getSlotElementId(); if (ad_id == 'div-gpt-ad-1659428980688-0') { var ad = $('#'+ad_id).find('iframe'); if ($(ad).width() == 728) { var ww = $(window).width(); ww = ww*0.90; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/728+","+ww/728+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/728+","+ww/728+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/728+","+ww/728+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/728+","+ww/728+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(90*ww/728)+"px;width:"+728+"px;}", 0 ); } else { if ($(window).width() < 340) { var ww = $(window).width(); ww = ww*0.875; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/320+","+ww/320+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/320+","+ww/320+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/320+","+ww/320+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/320+","+ww/320+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(180*ww/320)+"px;width:"+320+"px;}", 0 ); } } } }); }); } else { document.write('
'); document.write('
'); }
Perlで作るモバイルサイトのコツ

Perlで作るモバイルサイトのコツ:第2回

CPANモジュールでデコメールを作成する


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

本連載では、Perlによる携帯サイトを構築する上で役立つ、さまざまなTipsを解説していきます。第2回は、CPANモジュールのMIME::Liteを使ったサンプルを用いて、デコメールの基本的な仕様について解説します。

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

はじめに

 若い世代の女性を中心にデコメールが注目されています。

 デコメールとはNTTドコモのFOMA900iシリーズから導入された簡易HTMLメール機能で、HTMLメールならではの文字修飾、画像の埋め込みなどが可能です。これらの機能を使えば、ただのテキストのメールよりも個性的でかわいいメールを送ることができるので、それが人気につながっているようです。

 デコメールの仕様は下記で公開されています。

 本稿ではCPANモジュールのMIME::Liteを使ったサンプルを用いて、デコメールの基本的な仕様について解説します。

 ※CPANについては、第1回を参照してください。

対象読者

  • PerlでCGIアプリケーションを作成したことのある方。
  • CPANモジュールを使用したことのある方。
  • 携帯サイトでデコメールを配信しようとされている方。

必要な環境

 Perl 5.8以上が動作し、メールを送信することができるサーバ。

デコメールのパターン

 大きく分けてデコメールには、以下の4つのパターンがあります。

  1. HTMLのみ
    HTMLのみを送信するパターンです。
  1. HTML+画像添付
    HTMLに併せて画像を添付するパターンです。
  1. HTML+インライン画像
    HTML内に画像をインライン表示させるパターンです。
  1. デコメールテンプレート
    デコメールテンプレートと呼ばれるデコメールの雛形を扱うパターンです。ユーザーは、このテンプレートを編集して送信することができます。

 それでは、これら4つのパターンについて、サンプルと併せて見ていきましょう。

HTMLのみ

 HTMLのみのMIMEフォーマットは下記のようになります。

図1:HTMLのみの場合
図1:HTMLのみの場合

 Content-Typeをmultipart/alternativeとして、TEXTパートとHTMLパートを送信します。デコメール非対応端末には、TEXTパートのみ送信されることになりますので、必ずTEXTパートをつけるようにしましょう。

sample1.pl
#!/usr/local/bin/perl

use strict;
use MIME::Lite;
use Jcode;

my $text = 'お誕生日おめでとう';
my $html = <<'';
<html>
<body>
<font color="#FF0000">お誕生日おめでとう</font>
</body>
</html>

my $msg = MIME::Lite->new(
    Type     => 'multipart/alternative',
    Subject  => 'Happy Birthday!!',
    From     => '送信元アドレス',
    To       => '送信先アドレス',
    Encoding => '8bit',
);

# HTMLパート(対応端末に送信される部分)
$msg->attach(
    Type => 'text/html',
    Data => Jcode->new($html)->sjis,
    Encoding => '8bit',
);

# TEXTパート(非対応端末に送信される部分)
$msg->attach(
    Type => 'text/plain',
    Data => $text,
    Encoding => '8bit',
);

$msg->send;

HTML+画像添付

 画像を添付する場合は、下記のようなMIMEフォーマットになります(GIFファイルを添付した例です)。

図2:HTMLに画像を添付する場合
図2:HTMLに画像を添付する場合

 Content-Typeはmultipart/mixedで送信します。添付ファイルは、GIF・JPG・SWFファイルが利用できます。

sample2.pl
#!/usr/local/bin/perl

use strict;
use MIME::Lite;
use Jcode;
use Path::Class;

my $text = 'お誕生日おめでとう';
my $html = <<'';
<html>
<body>
<font color="#FF0000">お誕生日おめでとう</font>
</body>
</html>

my $body = MIME::Lite->new(
    Type => 'multipart/alternative',
);

$body->attach(
    Type => 'text/plain',
    Data => $text,
    Encoding => '8bit',
);

$body->attach(
    Type => 'text/html',
    Data => Jcode->new($html)->sjis,
    Encoding => '8bit',
);

# 添付する画像ファイル(base64でエンコード)
my $image = MIME::Lite->new(
    Type => 'image/gif; name="cake"',
    Data => scalar file('.', 'cake.gif')->slurp,
    Encoding => 'base64',
);

my $msg = MIME::Lite->new(
    Type     => 'multipart/mixed',
    Subject  => 'Happy Birthday!!',
    From     => '送信元アドレス',
    To       => '送信先アドレス',
    Encoding => '8bit',
);

$msg->attach($body);
$msg->attach($image);
$msg->send;

会員登録無料すると、続きをお読みいただけます

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

次のページ
HTML+インライン画像

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
Perlで作るモバイルサイトのコツ連載記事一覧

もっと読む

この記事の著者

村上 洋一郎(ムラカミ ヨウイチロウ)

株式会社ライブドア メディア事業部 モバイルメディア部所属。占いサイトやコミュニティサイトなど、様々なエンタメ系サイトの開発を担当しています。

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/550 2008/08/26 13:51
" ); }

おすすめ

アクセスランキング

  1. 1
    GenAI、「生成AI大賞2024」の各賞を発表。グランプリは名古屋鉄道が受賞 NEW
  2. 2
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    フロントエンドの定番ライブラリ「React 19」の新機能を紹介──アクションによる非同期処理の進化
  5. 5
    「どこか他人ごと」な防災DX、実際どれだけ進んでいる? 国・自治体が提供しているシステムと自分でできる備え
  1. 6
    経営とエンジニアリングをつなぐ鍵?──開発生産性×技術投資コストのダッシュボード設計 NEW
  2. 7
    Next.js 14までの進化を振り返る──App Routerを強化する新機能を解説!
  3. 8
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  4. 9
    IPA、DXの先進事例を素早く効率的に検索できるWebサイト「デジタル事例データベース」を公開
  5. 10
    NVIDIA、コンパクトな生成AIスーパーコンピューターを発表

アクセスランキング

  1. 1
    GenAI、「生成AI大賞2024」の各賞を発表。グランプリは名古屋鉄道が受賞 NEW
  2. 2
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    フロントエンドの定番ライブラリ「React 19」の新機能を紹介──アクションによる非同期処理の進化
  5. 5
    「どこか他人ごと」な防災DX、実際どれだけ進んでいる? 国・自治体が提供しているシステムと自分でできる備え
  6. 6
    経営とエンジニアリングをつなぐ鍵?──開発生産性×技術投資コストのダッシュボード設計 NEW
  7. 7
    Next.js 14までの進化を振り返る──App Routerを強化する新機能を解説!
  8. 8
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  9. 9
    IPA、DXの先進事例を素早く効率的に検索できるWebサイト「デジタル事例データベース」を公開
  10. 10
    NVIDIA、コンパクトな生成AIスーパーコンピューターを発表
  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    ITエンジニア本大賞2025、投票締切直前! みんなで選んだ歴代の大賞本を振り返って一挙紹介
  4. 4
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  5. 5
    2024年12月に開催される注目のITエンジニア向けカンファレンス5選
  6. 6
    日本在住の英語を話すソフトウェア開発者、年収の中央値は950万円に
  7. 7
    Vue.js3.4~3.5の新機能をまとめて紹介! 新しいAPIやSSRの改善
  8. 8
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  9. 9
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  10. 10
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

メールバックナンバー

アクセスランキング

  1. 1
    GenAI、「生成AI大賞2024」の各賞を発表。グランプリは名古屋鉄道が受賞 NEW
  2. 2
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    フロントエンドの定番ライブラリ「React 19」の新機能を紹介──アクションによる非同期処理の進化
  5. 5
    「どこか他人ごと」な防災DX、実際どれだけ進んでいる? 国・自治体が提供しているシステムと自分でできる備え
  1. 6
    経営とエンジニアリングをつなぐ鍵?──開発生産性×技術投資コストのダッシュボード設計 NEW
  2. 7
    Next.js 14までの進化を振り返る──App Routerを強化する新機能を解説!
  3. 8
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  4. 9
    IPA、DXの先進事例を素早く効率的に検索できるWebサイト「デジタル事例データベース」を公開
  5. 10
    NVIDIA、コンパクトな生成AIスーパーコンピューターを発表

アクセスランキング

  1. 1
    GenAI、「生成AI大賞2024」の各賞を発表。グランプリは名古屋鉄道が受賞 NEW
  2. 2
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    フロントエンドの定番ライブラリ「React 19」の新機能を紹介──アクションによる非同期処理の進化
  5. 5
    「どこか他人ごと」な防災DX、実際どれだけ進んでいる? 国・自治体が提供しているシステムと自分でできる備え
  6. 6
    経営とエンジニアリングをつなぐ鍵?──開発生産性×技術投資コストのダッシュボード設計 NEW
  7. 7
    Next.js 14までの進化を振り返る──App Routerを強化する新機能を解説!
  8. 8
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  9. 9
    IPA、DXの先進事例を素早く効率的に検索できるWebサイト「デジタル事例データベース」を公開
  10. 10
    NVIDIA、コンパクトな生成AIスーパーコンピューターを発表
  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    ITエンジニア本大賞2025、投票締切直前! みんなで選んだ歴代の大賞本を振り返って一挙紹介
  4. 4
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  5. 5
    2024年12月に開催される注目のITエンジニア向けカンファレンス5選
  6. 6
    日本在住の英語を話すソフトウェア開発者、年収の中央値は950万円に
  7. 7
    Vue.js3.4~3.5の新機能をまとめて紹介! 新しいAPIやSSRの改善
  8. 8
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  9. 9
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  10. 10
    管理職の24.1%、今後管理職を「続けたくない」と回答。理由は「責任やストレス」が最多に