まとめてサニタイズする方法として下記のように書いてみました。
引数が配列でなければ問題ないのですが、配列だとこんなエラーが出ます。
Warning: array_map() expects parameter 1 to be a valid callback, function 'sanitize' not found or invalid function name in ファイル名
foreachでまわすのも考えましたが、できるならスマートにと思っているのですが
どうすれば再帰的な処理ができるでしょうか?
$valid = new Valid();
$array = array(
'あああ','いいい','ううう',
);
$valid->sanitize( $array );
class Valid{
public function sanitize( $str ){
if ( is_array( $str ) ) return array_map( 'sanitize', $str );
return str_replace( "\0", '', $str );
}
}
No.2ベストアンサー
- 回答日時:
オブジェクト内のメソッドを動的に指定するcallableは
array($this, 'sanitize')
です。
また、クラス内のメソッドを静的に指定するcallableは
array(__CLASS__, 'sanitize')
です。PHP5.3以降では
'Valid::sanitize'
のように書くことも出来ます。
なお、配列再帰処理でしたらarray_walk_recursiveを使うのが一番速いですよ。
http://php.net/manual/ja/function.array-walk-rec …
(5.3以降のみのクロージャを使用しています)
class Valid {
____
____public static function sanitize($input) {
________if (is_array($input)) {
____________array_walk_recursive($input, function(&$v) {
________________$v = str_replace("\0", '', $v);
____________});
________} else {
____________$input = str_replace("\0", '', $input);
________}
________return $input;
____}
____
}
(この指摘をすると質問の前提条件自体が崩れると思いますが)
そもそもNULLバイトを削除したところで安全対策になるかどうかというと疑問です。
現在のPHPの多くの関数はバイナリセーフなのでNULLバイトを含んでいても正しく処理できます。
それよりもUTF-8エンコーディングバリデーションの方が必要な気がします。
私はこんな感じで、リクエストを処理する部分にエンコーディングバリデーションも組み込んでいますね。
http://qiita.com/mpyw/items/c39b9ee695a5c2e74627
【preg_match関数でパターンにu修飾子をつけたとき】
不正エンコーディングが見つかった際、返り値は必ずFALSEになります
【preg_replace関数でパターンにu修飾子をつけたとき】
不正エンコーディングが見つかった際、返り値は必ずNULLになります
わかりやすい回答をありがとうございました。
5.2のサーバーなので以下のようにして動作させることができました。
if ( is_array( $value ) ) return array_map( array( $this, 'sanitize' ), $value );
NULLバイト削除以下は略しましたが文字コードの設定やスペースの削除など一通りの処理を行っています。
qiitaのソースも是非参考にさせていただきます!
No.1
- 回答日時:
sanitizeは普通の関数じゃなくて、メソッドなので、オブジェクトに対して -> 経由での呼び出ししか出来ません。
つまり、array_map の引数に渡せません。Validというクラスで何をしたいのかいまいちわかりません。クラスとオブジェクトについて、よく理解されてないのではないかと思います。
とりあえず動くようにすると、
$valid = new Valid();
$array = array(
"ああ\0あ","いいい","ううう",
);
debug_zval_dump($array);
$array = $valid->sanitize( $array );
debug_zval_dump($array);
class Valid{
public function sanitize($str){
return Valid::sanitizesub($str);
}
public static function sanitizesub( $str ){
if ( is_array( $str ) ) return array_map( "Valid::sanitizesub", $str );
return str_replace( "\0", '', $str );
}
}
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(プログラミング・Web制作) laravel 本番環境でメールが送れません。 1 2023/02/17 17:57
- オープンソース Python openpyxlを使用したセル番地の使用について 1 2023/08/03 22:05
- PHP PHPでCSVを出力するさいに、ループの中で前の行の値を変更したい 3 2022/10/27 17:44
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- C言語・C++・C# c言語の問題です 課題1 (二分探索木とセット) 大きさ size の配列 array を考える。す 2 2023/01/10 21:08
- PHP PHPでCSVを出力するさいに、ループの中で前の行の値を変更したい 1 2022/10/27 14:21
- JavaScript 2段階プルダウンで1段階目の選択を終えた後に選択ボックスを見えなくしたい 2 2022/07/05 21:58
- Visual Basic(VBA) VBAでfunctionを利用しようとしたときに「引数は省略できません」というエラーが出ます 1 2022/10/15 16:30
- その他(プログラミング・Web制作) listへのappendが出来ない件 1 2022/12/06 21:44
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
スカラーのベクトル微分
-
php で1から100までの素数の表...
-
PHPのmin関数、「1」以上の数値...
-
pythonのnumpyでの繰り返しでの...
-
C言語 最大値と最小値を求めて...
-
STLのvectorで作った配列をメン...
-
CArrayの要素としてCStringArra...
-
Pager::factory()の使い方がわ...
-
C言語で全角文字の扱いについて
-
数独かを判断するプログラム
-
PDOのバインドをforeachでまと...
-
C言語の配列をPush(追加)する...
-
PHPは何故値渡しより参照渡しの...
-
行列
-
System.String.Splitでエラー
-
連想配列から<th>を含むテーブ...
-
np.stack()とnp.array()の違い
-
am()の使い方
-
cakephpでのトランザクション処...
-
verilogで、配列の一部をタスク...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
スカラーのベクトル微分
-
STLのvectorで作った配列をメン...
-
特定の文からメールアドレスの...
-
配列の要素(value)に、変数を...
-
読み(あ行~わ行)ごとに分け...
-
ファイルの書き込みについて教...
-
verilogで、配列の一部をタスク...
-
CArrayの要素としてCStringArra...
-
pythonのnumpyでの繰り返しでの...
-
C言語の配列をPush(追加)する...
-
php キーソート キーが重複した...
-
CArrayのソート
-
【PHP】配列のキー名の修正は可...
-
多次元配列をエンコードする関...
-
PHPは何故値渡しより参照渡しの...
-
cakephpでのトランザクション処...
-
pg_copy_fromの使い方について...
-
array_intersectで空欄を比較し...
-
濁点のソート
-
配列中のあるキー、値を取得し...
おすすめ情報