Web aym.pekori.to

mb_output_handler

(PHP 4 >= 4.0.6, PHP 5)

mb_output_handler --  出力バッファ内で文字エンコーディングを変換するコールバック関数

説明

string mb_output_handler ( string contents, int status )

mb_output_handler() は、 ob_start() のコールバック関数です。 mb_output_handler() は、出力バッファの文字を 内部文字エンコーディングから HTTP 出力文字エンコーディングに変換します。

4.1.0 以降のバージョンでは、以下の条件が満たされた場合にこのハンドラは charset HTTP ヘッダを設定します。

contents : 出力バッファの内容

status : 出力バッファのステータス

返り値: 変換後の文字列

例 1. mb_output_handler() の例

<?php
mb_http_output
("UTF-8");
ob_start("mb_output_handler");
?>

注意: PHP 4.3.0 以降において、 イメージのようなバイナリデータを PHP スクリプトから出力したい場合、 バイナリデータを送信する前に header() により Content-Type: ヘッダ(例:header("Content-Type: image/png"))を 送信する必要があります。Content-Type: ヘッダが送信されると出力文字 コード変換は無効となります。

ただし、header() により"Content-Type: text/*" を送信した場合には、テキストが送信されるとみなし、文字コード設定に 基づいて出力文字コード変換を行います。

なお、PHP 4.2.x あるいはそれ以前のバージョンで画像のようなバイナリデータを 出力する場合には、mb_http_output() を用いて 出力エンコーディングを "pass" に設定する必要があります。

ob_start() も参照ください。