Input validation with filter functions

Introduction
Although PHP has a lot of filter functions available, I found that still to many people are using (often incorrect) regular expressions to validate user input. The filter extension is simple, standard available and will fulfill the common validations. Below some pratical examples and things to consider when working with PHP filter functions.

Which are available?
Below a shameless copy paste of the PHP documentation.

  • filter_has_var — Checks if variable of specified type exists
  • filter_id — Returns the filter ID belonging to a named filter
  • filter_input_array — Gets external variables and optionally filters them
  • filter_input — Gets a specific external variable by name and optionally filters it
  • filter_list — Returns a list of all supported filters
  • filter_var_array — Gets multiple variables and optionally filters them
  • filter_var — Filters a variable with a specified filter

Pratical use

Sanitizing
“Filter input escape output” every developer knows this but it is a repetitive job but with the filter extension filterering input became a lot easier. When you correctly filter input you drastically lower the change of application vulnerabilities.

Sanitizing a single variable

$sText = ' ';
$sText = filter_var($sText, FILTER_SANITIZE_STRING);
echo $sText; // This is a comment from a alert("scriptkiddie");

Sanitizing multiple variables, same principle as above but with an array, the filter will sanitize all values inside the array

filter_var_array($_POST, FILTER_SANITIZE_STRING);

Validating an email address

if(filter_var($sEmail, FILTER_VALIDATE_EMAIL) === false) {
     $this->addError('Invalid email address', $sEmail);
}

Validation a complete array
Validating all your data at once with a single filter will make your code clear, all in one place and is more easy to maintain an example below.

$aData = array(
	'student'	=> 'Sjoerd Maessen',
	'class'		=> '21',
	'grades' => array(
			'math' => 9,
			'geography' => 66,
			'gymnastics' => 7.5
	)
);

$aValidation = array(
	'student'	=> FILTER_SANITIZE_STRING,
	'class'		=> FILTER_VALIDATE_INT,
	'grades'	=> array(
				'filter' => FILTER_VALIDATE_INT,
				'flags'	 => FILTER_FORCE_ARRAY,
				'options'=> array('min_range'=>0, 'max_range'=>10))
);

echo '
';
var_dump(filter_var_array($aData, $aValidation));

/*array(3) {
  ["student"]=>
  string(14) "Sjoerd Maessen"
  ["class"]=>
  int(21) // Thats strange, my string is converted
  ["grades"]=>
  array(3) {
    ["math"]=>
    int(9)
    ["geography"]=>
    bool(false) // 66 is > 10
    ["gymnastics"]=>
    bool(false) // 7.5 is not an int
  }
}*/

Note: okay I did not expect that the string '21' would validate true against FILTER_VALIDATE_INT, after some more testing I also noticed that min_range and max_range only work with FILTER_VALIDATE_INT, when using floats or scalars the options are just ignored, so be aware!

The sanitizing examples above can be made easily more restrictive by adding flags like FILTER_FLAG_STRIP_LOW to the sanitize filter, FILTER_FLAG_STRIP_LOW will for example strip all characters that have a numerical value below 32.

Things to consider
Although the filter functions are some time available some of them aren't flawless, at some points the documentation is missing or very unclear. Another example is the filter_var validation for IPv6 addresses. (see bug report #50117). So it is always a good thing to check if the filter is really doing what you expect it does. Write testcases before using. If you use it correctly you can write your validations in the blink of an eye, and this extension will be your new best friend.

Links
Filter functions
Filter flags

Comments

6,533 responses to “Input validation with filter functions”

  1. Michaeldum Avatar
    Michaeldum

    https://drindiameds.com/# Indian pharmacy coupon codes

  2. Robertinvok Avatar
    Robertinvok

    best online pharmacies Canada to USA: Doctor North Rx – trusted Canadian generics

  3. LarryAMORA Avatar
    LarryAMORA

    verified Mexican pharmacies USA delivery certified Mexican pharmacy discounts generic medicine from Mexico

  4. Curtisvax Avatar
    Curtisvax

    verified Indian drugstores: indian pharmacy online – Dr India Meds

  5. JerryAmure Avatar
    JerryAmure

    indian pharmacy DrIndiaMeds india pharmacy

  6. AlvinVew Avatar

    Официальный сайт компании — https://www.ewebdiscussion.com/threads/bonus-2026.330453/

  7. vibekingis8zef Avatar
    vibekingis8zef

    Je ne me lasse pas de Azur Casino, il propose une aventure palpitante. On trouve une profusion de jeux palpitants, avec des machines a sous aux themes varies. Avec des depots fluides. Le suivi est d’une fiabilite exemplaire. Les transactions sont fiables et efficaces, par ailleurs quelques tours gratuits en plus seraient geniaux. Au final, Azur Casino est un immanquable pour les amateurs. A signaler l’interface est intuitive et fluide, booste l’excitation du jeu. Particulierement cool les tournois frequents pour l’adrenaline, propose des privileges sur mesure.
    Parcourir le site|

  8. Curtisvax Avatar
    Curtisvax

    trusted Mexican drugstores online: DrMedsAdvisor – safe medications from Mexico

  9. JerryAmure Avatar
    JerryAmure

    Dr India Meds indian pharmacy india pharmacy

  10. Robertinvok Avatar
    Robertinvok

    Mexico to USA pharmacy shipping: Dr Meds Advisor – certified Mexican pharmacy discounts

  11. Michaeldum Avatar
    Michaeldum
  12. Robertinvok Avatar
    Robertinvok

    canadian pharmacy online: DoctorNorthRx – trusted Canadian generics

  13. ToxicPoweros2zef Avatar
    ToxicPoweros2zef

    Je suis enthousiasme par Azur Casino, il cree une experience captivante. Les options de jeu sont incroyablement variees, comprenant des jeux optimises pour Bitcoin. Il propulse votre jeu des le debut. Le suivi est d’une precision remarquable. Les retraits sont lisses comme jamais, quelquefois plus de promos regulieres dynamiseraient le jeu. Dans l’ensemble, Azur Casino vaut une visite excitante. A signaler l’interface est lisse et agreable, facilite une immersion totale. Particulierement cool les tournois reguliers pour la competition, assure des transactions fiables.
    Emmenez-moi lГ -bas|

  14. dreamcodeax7zef Avatar
    dreamcodeax7zef

    J’adore l’ambiance electrisante de Lucky 31 Casino, c’est un lieu ou l’adrenaline coule a flots. Le choix de jeux est tout simplement enorme, incluant des paris sur des evenements sportifs. Il propulse votre jeu des le debut. Disponible 24/7 pour toute question. Les gains arrivent en un eclair, en revanche plus de promos regulieres ajouteraient du peps. Pour finir, Lucky 31 Casino assure un fun constant. Par ailleurs l’interface est intuitive et fluide, booste le fun du jeu. Particulierement cool les options variees pour les paris sportifs, offre des recompenses regulieres.
    Essayer ceci|

  15. NeoWaveik6zef Avatar
    NeoWaveik6zef

    Je suis fascine par 1xBet Casino, il procure une sensation de frisson. Les options sont aussi vastes qu’un horizon, offrant des tables live interactives. 100% jusqu’a 500 € avec des free spins. Le support client est irreprochable. Les gains sont verses sans attendre, parfois des bonus plus varies seraient un plus. Globalement, 1xBet Casino est une plateforme qui fait vibrer. Pour couronner le tout l’interface est fluide comme une soiree, ce qui rend chaque partie plus fun. Un point cle les transactions crypto ultra-securisees, qui booste la participation.
    Obtenir les dГ©tails|

  16. stormspinok7zef Avatar
    stormspinok7zef

    Je suis sous le charme de 1xBet Casino, c’est une plateforme qui deborde de dynamisme. Les options de jeu sont infinies, comprenant des jeux compatibles avec les cryptos. Avec des depots fluides. Le suivi est toujours au top. Le processus est simple et transparent, a l’occasion quelques free spins en plus seraient bienvenus. Pour finir, 1xBet Casino vaut une visite excitante. En plus l’interface est lisse et agreable, ce qui rend chaque partie plus fun. A mettre en avant les competitions regulieres pour plus de fun, garantit des paiements rapides.
    Essayer ceci|

  17. neovibeus4zef Avatar
    neovibeus4zef

    J’ai un faible pour 1xBet Casino, ca invite a l’aventure. On trouve une profusion de jeux palpitants, incluant des paris sur des evenements sportifs. Il offre un coup de pouce allechant. Les agents repondent avec rapidite. Les paiements sont securises et instantanes, mais des bonus plus frequents seraient un hit. Au final, 1xBet Casino est un lieu de fun absolu. A souligner la plateforme est visuellement vibrante, facilite une experience immersive. Un atout les nombreuses options de paris sportifs, garantit des paiements rapides.
    Voir les dГ©tails|

  18. novapowerok3zef Avatar
    novapowerok3zef

    Je suis emerveille par Lucky 31 Casino, on ressent une ambiance festive. Il y a une abondance de jeux excitants, proposant des jeux de casino traditionnels. Il rend le debut de l’aventure palpitant. Le support est rapide et professionnel. Les retraits sont fluides et rapides, cependant des offres plus genereuses seraient top. Pour faire court, Lucky 31 Casino merite une visite dynamique. En plus l’interface est fluide comme une soiree, incite a rester plus longtemps. A noter les tournois reguliers pour s’amuser, propose des privileges personnalises.
    Commencer Г  lire|

  19. driftriseen3zef Avatar
    driftriseen3zef

    Je suis accro a Action Casino, il propose une aventure palpitante. La bibliotheque est pleine de surprises, offrant des sessions live immersives. Il offre un demarrage en fanfare. Le suivi est d’une fiabilite exemplaire. Les paiements sont securises et rapides, malgre tout quelques free spins en plus seraient bienvenus. En conclusion, Action Casino vaut une visite excitante. A souligner le site est fluide et attractif, permet une immersion complete. A noter les paiements securises en crypto, garantit des paiements rapides.
    Emmenez-moi lГ -bas|

  20. Curtisvax Avatar
    Curtisvax

    best online pharmacies Canada to USA: safe Canadian pharmacies for Americans – canadian pharmacy

  21. AndrewMaw Avatar

    Мезонин в Москве Антресольный этаж: Антресольный этаж – это, по сути, промежуточный этаж в здании, расположенный обычно между двумя основными этажами. Его ключевая особенность – меньшая площадь по сравнению с основными этажами, что позволяет создавать компактное, но функциональное пространство. Использование антресольных этажей позволяет эффективно задействовать вертикальное пространство зданий, особенно там, где высота потолков позволяет это сделать. В зависимости от назначения здания, антресоли могут использоваться как для офисных помещений, так и для организации дополнительных жилых зон или хранения. Важно отметить, что при проектировании антресольного этажа необходимо учитывать строительные нормы и правила безопасности, а также обеспечить достаточную освещенность и вентиляцию. Антресольный этаж – это не только функциональное, но и зачастую дизайнерское решение, позволяющее создать интересный архитектурный облик помещения.

  22. JerryAmure Avatar
    JerryAmure

    affordable medications from Canada affordable medications from Canada legitimate pharmacy shipping to USA

  23. Harveyhop Avatar

    Женский блог https://sunshadow.com.ua о жизни без перегруза: красота и здоровье, отношения и семья, стиль и покупки, деньги и карьера. Честные обзоры, лайфхаки, планы на неделю и личные истории — только то, что реально помогает.

  24. ThomasDam Avatar

    Современный женский https://timelady.kyiv.ua сайт о стиле жизни: уход за собой, макияж, прически, фитнес, питание, мода и деньги. Практичные советы, разбор трендов, подборки покупок и личная эффективность. Будь в ресурсе и чувствуй себя уверенно каждый день. Больше — внутри.

  25. JerryAmure Avatar
    JerryAmure

    safe Canadian pharmacies for Americans Doctor North Rx doctor recommended Canadian pharmacy

  26. Curtisvax Avatar
    Curtisvax

    mexican pharmacy: Dr Meds Advisor – trusted Mexican drugstores online

  27. Robertinvok Avatar
    Robertinvok

    DoctorNorthRx: trusted Canadian generics – verified Canada drugstores

  28. LarryAMORA Avatar
    LarryAMORA

    doctor recommended Mexican pharmacy safe medications from Mexico Mexico to USA pharmacy shipping

  29. AlbertFoume Avatar

    Блог для женщин https://sweetheart.kyiv.ua которые выбирают себя: самоценность, баланс, карьера, финансы, хобби и путешествия. Мини-привычки, трекеры, вдохновляющие тексты и практичные советы.

  30. Robertinvok Avatar
    Robertinvok

    indian pharmacy: affordable Indian medications online – Dr India Meds

  31. MarvinNeeno Avatar

    Портал для женщин https://viplady.kyiv.ua ценящих стиль, комфорт и развитие. Мода, уход, отношения, семья и здоровье. Только практичные советы, экспертные мнения и вдохновляющий контент. Узнай, как быть собой и чувствовать себя лучше.

  32. Michaellep Avatar

    Онлайн-площадка https://topwoman.kyiv.ua для женщин: стиль, бьюти-новинки, осознанность, здоровье, отношения, материнство и работа. Экспертные статьи, инструкции, чек-листы, тесты и вдохновение. Создавай лучший день, развивайся и находи ответы без лишней воды.

  33. Curtisvax Avatar
    Curtisvax

    Doctor North Rx: canadianpharmacyworld com – precription drugs from canada

  34. JerryAmure Avatar
    JerryAmure

    indian pharmacy safe Indian generics for US patients trusted medical sources from India

  35. ShaneDrync Avatar
    ShaneDrync

    Pretty component of content. I simply stumbled upon your website and in accession capital to assert that I acquire actually enjoyed account your weblog posts. Any way I will be subscribing in your augment and even I success you get entry to constantly rapidly.
    https://lawak88.com/promokod-toto-melbet-2025/

  36. PetercoW Avatar

    Женский медиасайт https://woman365.kyiv.ua с акцентом на пользу: капсульный гардероб, бьюти-рутины, здоровье, отношения, саморазвитие и материнство. Пошаговые инструкции, списки покупок, чек-листы и экспертные ответы. Заботимся о тебе и твоем времени. Подробности — на сайте.

  37. LarryAMORA Avatar
    LarryAMORA

    trusted medical sources from India Indian pharmacy coupon codes safe Indian generics for US patients

  38. EugeneDency Avatar

    Проектирование Металлоконструкция: Металлоконструкция – это конструкция, изготовленная из металла, используемая в строительстве и промышленности для создания различных сооружений и изделий. Металлоконструкции отличаются высокой прочностью, долговечностью и надежностью. Они могут быть использованы для строительства зданий, мостов, складов, ангаров и других сооружений. Металлоконструкции широко применяются в строительстве благодаря своей универсальности и возможности создавать сложные архитектурные формы. При проектировании металлоконструкций необходимо учитывать нагрузки и условия эксплуатации. Металлоконструкции проходят контроль качества на каждом этапе производства, чтобы гарантировать их надежность и безопасность.

  39. JerryAmure Avatar
    JerryAmure

    legitimate pharmacy shipping to USA safe Canadian pharmacies for Americans DoctorNorthRx

  40. Robertinvok Avatar
    Robertinvok

    canadian pharmacy: best online pharmacies Canada to USA – Doctor North Rx

Leave a Reply

Your email address will not be published. Required fields are marked *