iconv_mime_decode

(PHP 5, PHP 7, PHP 8)

iconv_mime_decodeMIME ヘッダフィールドをデコードする

説明

iconv_mime_decode(string $string, int $mode = 0, ?string $encoding = null): string|false

MIME ヘッダフィールドをデコードします。

パラメータ

string

エンコードされたヘッダを表す文字列。

mode

mode は、iconv_mime_decode() が不正な形式の MIME ヘッダフィールドに遭遇した場合の 振る舞いを定義します。以下のビットマスクの組み合わせで指定が可能です。

iconv_mime_decode() で指定できるビットマスク
定数名 説明
1 ICONV_MIME_DECODE_STRICT 指定すると、ヘッダは » RFC2047 で定義されている標準に完全準拠する形式でデコードされます。 このオプションはデフォルトでは無効になっています。なぜなら、世の中には おかしなメールソフトが多く存在し、それらは規格に従わずに間違った MIME ヘッダを生成するからです。
2 ICONV_MIME_DECODE_CONTINUE_ON_ERROR 指定すると、iconv_mime_decode_headers() は文法的なエラーを無視し、デコード作業を継続します。

encoding

オプションの encoding パラメータは、結果の 文字セットを指定します。指定されなかった場合、もしくは null の場合は iconv.internal_encoding が用いられます。

戻り値

成功した場合はデコードされた MIME フィールドを、 デコード中にエラーが発生した場合は false を返します。

変更履歴

バージョン 説明
8.0.0 encoding は、nullable になりました。

例1 iconv_mime_decode() の例

<?php
// この結果は "Subject: Prüfung Prüfung" となります。
echo iconv_mime_decode("Subject: =?UTF-8?B?UHLDvGZ1bmcgUHLDvGZ1bmc=?=",
                       
0"ISO-8859-1");
?>

参考

関連キーワード:  デコード, ヘッダ, フィールド, iconv, mime, decode, string, encoding, ビット, mode