送信メールのサブジェクトが長いと文字化けする

カテゴリ フォーム コアバージョン 7.16 関連モジュール Webform, Mail System, Mime Mail, Jp Mail Helper

一部のスマートフォンやメーラーでサブジェクトが文字化けする現象がありました。

Japan Mobile Helperモジュールを利用しているので、サブジェクトもISO-2022-JPにエンコードされています。
なのに文字化けしてしまいます。

コメント

ユーザー actbrain の写真

Japan Mail Helperの機能不足と思われます。

Japan Mail Helperでサブジェクトのエンコードを mb_encode_mimeheader に依頼していますが、
それ以前(hook_init)でmb_internal_encoding("UTF-8")としてしまっています。
その結果、mb_encode_mimeheader は内部エンコーディングによりサブジェクトを分割しようとします(※1)
その分割の際に内部エンコーディングに基づく分割を行ってしまいます。
ISO-2022-JPの文字列をUTF-8で分割したわけです。
※1)RFCによりサブジェクトが長い時は分割して記述するように規定されています。

措置として、Japan Mail Helperモジュールに下記変更が必要になります。
function jp_mail_helper_mime_header_encode($string) {
if (preg_match('/[^\x20-\x7E]/', $string)) {
+ mb_internal_encoding(JP_MAIL_HELPER_ENCODING_MAIL_HEADER); // 20121102144200 +
$string = mb_convert_encoding($string, JP_MAIL_HELPER_ENCODING_MAIL_HEADER, "UTF-8");
$string = mb_encode_mimeheader($string, JP_MAIL_HELPER_ENCODING_MAIL_HEADER);
+ mb_internal_encoding("UTF-8"); // 20121102144200 +
}
return $string;
}

参考:
http://www.onecreation.jp/blog/?p=1132

ユーザー actbrain の写真

その後の調査で上記措置は誤りであると解りました。

mb_encode_mimeheader()に渡す引数は、UTF-8で良く、iso-2022-jpに変換したり、内部円コーディングをiso-2022-jpにしたりするのは不要、問題でした。

正しくは下記になります。

if (preg_match('/[^\x20-\x7E]/', $string)) {
// 20121106024700 - + mb_internal_encoding(JP_MAIL_HELPER_ENCODING_MAIL_HEADER); // 20121102144200 +
// 20121106024700 - $string = mb_convert_encoding($string, JP_MAIL_HELPER_ENCODING_MAIL_HEADER, "UTF-8");
$string = mb_encode_mimeheader($string, JP_MAIL_HELPER_ENCODING_MAIL_HEADER);
// 20121106024700 - + mb_internal_encoding("UTF-8"); // 20121102144200 +
}

ページ

OTHER FAQ

Drupal開発・運用の疑問/質問の答えはここに

無料ユーザー登録すると質問できます。

カテゴリ Core Ver. 関連モジュール タイトル降順で並び替える
サイトの環境設定 8.9.x 編集
コンテンツの作成 7.15 Darty Form 編集ページでの操作ミス
サイトの環境設定 7.23 Pathauto 自動生成されるURLエイリアスがおかしい
フォーム 7.16 Webform, Mail System, Mime Mail, Jp Mail Helper 送信メールのサブジェクトが長いと文字化けする
ユーザ 7.23 User 長い投稿者名の表示が切れる
テーマ 8.9.x patch パッチ 開発環境のファイル変更を本番環境にパッチでデプロイする方法(画像含まず)
開発 mail 7.50 Mail Safety 開発/テスト用サイトのメール

ページ