関数・クラス解説

stream_filter_register

version:PHP 5, PHP 7 (公式)

ユーザー定義のストリームフィルタを登録する

公式リファレンス

書式

stream_filter_register ( string $filtername , string $classname ) : bool

説明

stream_filter_register() は、fopen() や fread() などのファイルシステムの関数で利用可能な 登録されているどの種類のストリームとも一緒に使うことのできる カスタムフィルタを登録します。

パラメータ

filtername
登録するフィルタ名。
classname
フィルタを実装するには、まず、php_user_filter を継承したクラスのメンバ関数を実装しなくてはなりません。 PHP は、書き込みまたは読み出し操作を カスタムフィルタの付加されたストリームに対して行う際に、まず データをそのフィルタに(そして、付加されている他のすべてのフィルタにも) 渡し、指示どおりストリームのデータが変更されるようにします。 メソッドの実装は、php_user_filter の説明の通りにしなければなりません。 さもないと、定義されていない動作をします。

返値

成功した場合に TRUE を、失敗した場合に FALSE を返します。 stream_filter_register() は、 指定された filtername がすでに定義されている場合、 FALSE を返します。

サンプル

例1 foo-bar.txt ストリームの文字を大文字化するフィルタ

下記の例は、読み込まれたり書き出されたりするデータに含まれるすべての英文字を 大文字化する strtoupper ストリームを実装し、foo-bar.txt ストリームに適用するものです。

/* フィルタクラスを定義する */ class strtoupper_filter extends php_user_filter {   function filter($in, $out, &$consumed, $closing)   {     while ($bucket = stream_bucket_make_writeable($in)) {       $bucket->data = strtoupper($bucket->data);       $consumed += $bucket->datalen;       stream_bucket_append($out, $bucket);     }     return PSFS_PASS_ON;   } } /* PHP にフィルタを登録する */ stream_filter_register("strtoupper", "strtoupper_filter")     or die("Failed to register filter"); $fp = fopen("foo-bar.txt", "w"); /* フィルタを開いたストリームに付加する */ stream_filter_append($fp, "strtoupper"); fwrite($fp, "Line1\n"); fwrite($fp, "Word - 2\n"); fwrite($fp, "Easy As 123\n"); fclose($fp); /* ファイルを読み出し出力する  */ readfile("foo-bar.txt");

上の例の出力は以下となります。

LINE1 WORD - 2 EASY AS 123

例2 複数のフィルタ名に対応する一般的なフィルタクラスを登録する

/* フィルタクラスを定義する */ class string_filter extends php_user_filter {   var $mode;   function filter($in, $out, &$consumed, $closing)   {     while ($bucket = stream_bucket_make_writeable($in)) {       if ($this->mode == 1) {         $bucket->data = strtoupper($bucket->data);       } elseif ($this->mode == 0) {         $bucket->data = strtolower($bucket->data);       }       $consumed += $bucket->datalen;       stream_bucket_append($out, $bucket);     }     return PSFS_PASS_ON;   }   function onCreate()   {     if ($this->filtername == 'str.toupper') {       $this->mode = 1;     } elseif ($this->filtername == 'str.tolower') {       $this->mode = 0;     } else {       /* その他の str.* フィルタが問い合わせられた場合は          失敗を報告し、PHP が検索を続けられるようにする */       return false;     }     return true;   } } /* PHP にフィルタを登録する */ stream_filter_register("str.*", "string_filter")     or die("Failed to register filter"); $fp = fopen("foo-bar.txt", "w"); /* フィルタを開いたストリームに付加する    ここで str.tolower をバインドすることも可能 */ stream_filter_append($fp, "str.toupper"); fwrite($fp, "Line1\n"); fwrite($fp, "Word - 2\n"); fwrite($fp, "Easy As 123\n"); fclose($fp); /* ファイルを読み出し出力する  */ readfile("foo-bar.txt");

上の例の出力は以下となります。

LINE1 WORD - 2 EASY AS 123

参考

  • stream_wrapper_register() - PHP のクラスとして実装された URL ラッパーを登録する
  • stream_filter_append() - ストリームにフィルタを付加する
  • stream_filter_prepend() - フィルタをストリームに付加する
  • ワード検索


    ※入力キーワードが、関数名・説明文・タグに含まれるものを検索

    関数名アルファベット別

    A B C D E F G H I J
    K L M N O P Q R S T
    U V W X Y Z _

    最終更新一覧

    stristr
     大文字小文字を区別せず文字列を検索し、ヒット箇所以降(あるいは以前)の文字列を返却

    stripslashes
     バックスラッシュでエスケープされた文字列から、バックスラッシュを取り除く

    stripos
     大文字小文字を区別せずに文字列が最初に現れる位置を取得する

    stripcslashes
     addcslashes() でクォートされた文字列をアンクォートする

    strip_tags
     文字列から HTML と PHP のタグを除去して返却

    strcspn
     指定した文字が最初に現れる位置を調べる

    strcoll
     ロケールに基づいて2つの文字列を比較し同じか(あるいは大小)を判定する

    strcmp
     2つの文字列を比較し同じか(あるいは大小)を判定する

    strchr
     strstr() のエイリアス

    strcasecmp
     2つの文字列を比較(大文字小文字を区別せず同じとみなす)

    カテゴリー一覧

    PHP の振る舞いの変更
    音声フォーマットの操作
    認証サービス
    コマンドライン関連
    圧縮およびアーカイブ
    暗号
    データベース関連
    日付および時刻関連
    ファイルシステム
    自然言語および文字エンコーディング
    画像処理および作成
    メール関連
    数学
    テキスト以外の MIME 型
    プロセス制御
    その他の基本モジュール
    その他のサービス
    検索エンジン用の拡張モジュール
    サーバー固有のモジュール
    セッション関連
    テキスト処理
    変数・データ型関連
    ウェブサービス
    Windows 用のモジュール
    XML 操作
    GUI用の拡張モジュール