Идея 1
Рассмотрите возможность использования FILTER_CALLBACK. Таким образом, вы можете написать функцию обратного вызова, которая сама использует расширение фильтра, обеспечивая рекурсивную возможность.
function validate_array($args) {
return function ($data) use ($args) {
return filter_input_array($data, $args);
};
}
Это сгенерирует функции обратного вызова.
$args = array(
'user' => array(
'filter' => FILTER_CALLBACK,
'options' => validate_array(array(
'age' => array('filter' => FILTER_INPUT_INT),
'email' => array('filter' => FILTER_INPUT_EMAIL)
))
)
);
Вот так будет выглядеть массив конфигурации.
Идея 2
Не стесняйтесь похлопать меня по спине за этот, потому что я очень горжусь этим.
Возьмите массив arg, который выглядит следующим образом. Трещины указывают на глубину.
$args = array(
'user/age' => array('filter' => FILTER_INPUT_INT),
'user/email' => array('filter' => FILTER_INPUT_EMAIL),
'user/parent/age' => array('filter' => FILTER_INPUT_INT),
'foo' => array('filter' => FILTER_INPUT_INT)
);
Предположим, ваши данные выглядят примерно так.
$data = array(
'user' => array(
'age' => 15,
'email' => 'foo@gmail.com',
'parent' => array(
'age' => 38
)
),
'foo' => 5
);
Затем вы можете сгенерировать массив ссылок, которые сопоставляют ключи, такие как 'user / age', с $ data ['user'] ['age']. В конечном производстве вы получите что-то вроде этого:
function my_filter_array($data, $args) {
$ref_map = array();
foreach ($args as $key => $a) {
$parts = explode('/', $key);
$ref =& $data;
foreach ($parts as $p) $ref =& $ref[$p];
$ref_map[$key] =& $ref;
}
return filter_var_array($ref_map, $args);
}
var_dump(my_filter_array($data, $args));
Теперь единственный вопрос - как вы справляетесь с несоответствием между проверочной записью и исходным набором данных. На это я не могу ответить, не зная, как их использовать.