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

691 responses to “Input validation with filter functions”

  1. Curtisvax Avatar
    Curtisvax

    verified Canada drugstores: safe Canadian pharmacies for Americans – legitimate pharmacy shipping to USA

  2. newboard-store-297 Avatar

    Портал о строительстве https://newboard-store.com.ua и ремонте: от проекта до сдачи объекта. Каталоги производителей, сравнение материалов, сметы, BIM и CAD, нормативная база, ленты новостей, вакансии и тендеры. Практика, цифры и готовые решения.

  3. carexpert-62 Avatar

    Современный автопортал https://carexpert.com.ua главные премьеры и тенденции, подробные обзоры, тест-драйвы, сравнения моделей и подбор шин. Экономия на обслуживании, страховке и топливе, проверки VIN, лайфхаки и чек-листы. Всё, чтобы выбрать и содержать авто без ошибок да

  4. vestionline-207 Avatar

    Современный новостной https://vestionline.com.ua портал: главные темы суток, лонгриды, мнения экспертов и объясняющие материалы. Проверка фактов, живые эфиры, инфографика, подборка цитат и контекст. Быстрый доступ с любого устройства и без лишних отвлечений.

  5. magictechtob Avatar

    Женский портал https://magictech.com.ua о жизни без перегруза: здоровье и красота, отношения и семья, финансы и карьера, дом и путешествия. Экспертные статьи, гайды, чек-листы и подборки. Только полезные советы и реальные истории.

  6. VernonAbsed Avatar

    Изоляторы Экструдированный пенополистирол (ЭППС) – это теплоизоляционный материал с закрытой ячеистой структурой, обладающий высокими теплоизоляционными свойствами и влагостойкостью. Применяется для утепления фасадов, фундаментов, кровель и других конструкций.

  7. Georgetar Avatar

    чижик магазины Магазин Чижик каталог товаров и цены – служит основным инструментом для информирования покупателей о текущем ассортименте и ценах. Каталог регулярно обновляется, отражая сезонные акции, скидки и специальные предложения. Это позволяет покупателям всегда быть в курсе самых выгодных предложений и планировать свои покупки заранее. Удобная навигация внутри каталога облегчает поиск необходимых товаров.

  8. Robertinvok Avatar
    Robertinvok

    doctor recommended Indian pharmacy: trusted medical sources from India – Indian pharmacy coupon codes

  9. Curtisvax Avatar
    Curtisvax

    verified Canada drugstores: trusted Canadian generics – legitimate pharmacy shipping to USA

  10. JerryAmure Avatar
    JerryAmure

    legitimate pharmacy shipping to USA verified Canada drugstores DoctorNorthRx

  11. Robertinvok Avatar
    Robertinvok

    Indian pharmacy coupon codes: DrIndiaMeds – DrIndiaMeds

  12. Michaeldum Avatar
    Michaeldum

    http://doctornorthrx.com/# trusted Canadian generics

  13. RalphTodia Avatar

    Главный автопортал https://newsgood.com.ua о драйве и прагматике: премьеры, технологии, электрокары, кроссоверы и коммерческий транспорт. Экспертные обзоры, тест-драйвы, подбор автокредита и страховки, расходы и сервис. Проверка истории авто и советы по экономии и сервисы.

  14. KennethPef Avatar

    Всё для женщины https://wonderwoman.kyiv.ua уход и макияж, мода и стиль, психология и отношения, работа и деньги, мама и ребёнок. Тренды, тесты, инструкции, подборки брендов и сервисов. Читайте, вдохновляйтесь, действуйте.

  15. MarcusSem Avatar

    Твой автопортал https://kia-sportage.in.ua о новых и подержанных машинах: рейтинги надёжности, разбор комплектаций, реальные тесты и видео. Помощь в покупке, кредит и страховка, расходы владения, ТО и тюнинг. Карта сервисов, советы по безопасности и сезонные рекомендации плюс

  16. CharlesThync Avatar

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

  17. JerryAmure Avatar
    JerryAmure

    certified Mexican pharmacy discounts verified Mexican pharmacies USA delivery Dr Meds Advisor

  18. LarryAMORA Avatar
    LarryAMORA

    no prescription pharmacy India medication online affordable Indian medications online

  19. Michaeldum Avatar
    Michaeldum

    https://doctornorthrx.xyz/# canadian pharmacy

  20. Alphawaveas7zef Avatar
    Alphawaveas7zef

    J’ai un veritable coup de c?ur pour Belgium Casino, il cree un monde de sensations fortes. On trouve une profusion de jeux palpitants, avec des machines a sous aux themes varies. Le bonus de depart est top. Le suivi est impeccable. Les paiements sont surs et efficaces, de temps en temps plus de promos regulieres dynamiseraient le jeu. En bref, Belgium Casino est un incontournable pour les joueurs. Pour ajouter le site est rapide et immersif, incite a prolonger le plaisir. Un element fort les options de paris sportifs variees, propose des avantages uniques.
    VГ©rifier ceci|

  21. Betavibeas4zef Avatar
    Betavibeas4zef

    Je suis sous le charme de Betway Casino, ca invite a plonger dans le fun. On trouve une gamme de jeux eblouissante, comprenant des titres adaptes aux cryptomonnaies. Le bonus de bienvenue est genereux. Les agents repondent avec rapidite. Les gains sont verses sans attendre, quelquefois des recompenses supplementaires dynamiseraient le tout. En resume, Betway Casino est un immanquable pour les amateurs. En bonus la navigation est simple et intuitive, ce qui rend chaque moment plus vibrant. Particulierement interessant les options de paris sportifs variees, cree une communaute soudee.
    Explorer le site web|

  22. Herbertmut Avatar

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

  23. Curtisvax Avatar
    Curtisvax

    verified Indian drugstores: trusted medical sources from India – safe Indian generics for US patients

  24. DarkWolfar8zef Avatar
    DarkWolfar8zef

    Je suis captive par Gamdom Casino, ca transporte dans un monde d’excitation. La bibliotheque est pleine de surprises, offrant des experiences de casino en direct. Il donne un elan excitant. Le support est fiable et reactif. Les transactions sont toujours fiables, parfois des offres plus consequentes seraient parfaites. En resume, Gamdom Casino vaut une visite excitante. En bonus le design est style et moderne, booste le fun du jeu. Un bonus les options variees pour les paris sportifs, propose des privileges sur mesure.
    https://gamdomcasino365fr.com/|

  25. Alphasoulis9zef Avatar
    Alphasoulis9zef

    Je suis sous le charme de Gamdom Casino, il propose une aventure palpitante. Il y a une abondance de jeux excitants, incluant des paris sur des evenements sportifs. 100% jusqu’a 500 € avec des free spins. Le support client est irreprochable. Les gains sont verses sans attendre, cependant quelques spins gratuits en plus seraient top. Pour conclure, Gamdom Casino assure un fun constant. Notons aussi le site est fluide et attractif, booste le fun du jeu. Un plus le programme VIP avec des privileges speciaux, qui booste la participation.
    https://gamdomcasino777fr.com/|

  26. Skykingin5zef Avatar
    Skykingin5zef

    J’ai un faible pour Belgium Casino, ca offre un plaisir vibrant. Les options de jeu sont incroyablement variees, offrant des sessions live palpitantes. Avec des depots fluides. Le support est efficace et amical. Les paiements sont securises et instantanes, par moments quelques free spins en plus seraient bienvenus. En fin de compte, Belgium Casino vaut une exploration vibrante. En extra le design est style et moderne, incite a prolonger le plaisir. Un plus les tournois frequents pour l’adrenaline, garantit des paiements securises.
    Voir plus|

  27. ShadowFlowis7zef Avatar
    ShadowFlowis7zef

    Je suis enthousiaste a propos de Betway Casino, on ressent une ambiance de fete. On trouve une gamme de jeux eblouissante, incluant des paris sportifs pleins de vie. Il donne un elan excitant. Le service d’assistance est au point. Les gains sont transferes rapidement, mais encore des bonus diversifies seraient un atout. En resume, Betway Casino merite un detour palpitant. En complement la plateforme est visuellement electrisante, permet une plongee totale dans le jeu. Un avantage notable les evenements communautaires engageants, offre des recompenses continues.
    Visiter aujourd’hui|

  28. Robertinvok Avatar
    Robertinvok

    affordable medications from Canada: verified Canada drugstores – Doctor North Rx

  29. LarryAMORA Avatar
    LarryAMORA

    indian pharmacy india pharmacy indian pharmacy

  30. Crimsonbeatix7zef Avatar
    Crimsonbeatix7zef

    Je suis accro a Betify Casino, il cree un monde de sensations fortes. La selection de jeux est impressionnante, proposant des jeux de casino traditionnels. Le bonus initial est super. Les agents sont rapides et pros. Les transactions sont d’une fiabilite absolue, cependant des recompenses additionnelles seraient ideales. Pour finir, Betify Casino vaut une visite excitante. A noter l’interface est intuitive et fluide, ce qui rend chaque session plus palpitante. Particulierement attrayant les options de paris sportifs variees, assure des transactions fluides.
    https://betifycasino365fr.com/|

  31. toxiccodeex9zef Avatar
    toxiccodeex9zef

    Je suis captive par Betify Casino, ca pulse comme une soiree animee. La bibliotheque est pleine de surprises, proposant des jeux de casino traditionnels. Il rend le debut de l’aventure palpitant. Le support est efficace et amical. Les retraits sont lisses comme jamais, par moments des bonus diversifies seraient un atout. Au final, Betify Casino est une plateforme qui fait vibrer. De plus l’interface est intuitive et fluide, facilite une experience immersive. A signaler les tournois frequents pour l’adrenaline, renforce la communaute.
    Ouvrir le site|

  32. BrightHeartex7zef Avatar
    BrightHeartex7zef

    Je suis fascine par Belgium Casino, on y trouve une energie contagieuse. Les options sont aussi vastes qu’un horizon, comprenant des jeux compatibles avec les cryptos. Avec des depots instantanes. Le service client est de qualite. Les gains arrivent sans delai, en revanche des bonus diversifies seraient un atout. Pour conclure, Belgium Casino merite une visite dynamique. Ajoutons que le design est moderne et energique, permet une plongee totale dans le jeu. Egalement excellent les options variees pour les paris sportifs, garantit des paiements rapides.
    Apprendre comment|

  33. CoreyMum Avatar

    Журнал об автомобилях https://svobodomislie.com без мифов: проверяем маркетинг фактами, считаем расходы владения, рассказываем о ТО, тюнинге и доработках. Тестируем новые и б/у, объясняем опции простыми словами. Экспертные мнения, идеи маршрутов и полезные чек-листы. Всегда!.

  34. Stevenwaink Avatar

    Еженедельный журнал https://sw.org.ua об авто и свободе дороги: премьеры, электромобили, кроссоверы, спорткары и коммерческий транспорт. Реальные тесты, долгосрочные отчёты, безопасность, кейсы покупки и продажи, кредит и страховка, рынок запчастей и сервисы рядом.

  35. Arthurwah Avatar

    Портал о балансе https://allwoman.kyiv.ua красота и самоуход, отношения и семья, развитие и карьера, дом и отдых. Реальные советы, капсульные гардеробы, планы тренировок, рецепты и лайфхаки. Ежедневные обновления и подборки по интересам.

  36. DevonPloro Avatar

    бездепозитный бонус слоты Представьте: вы получаете реальные деньги или фриспины (бесплатные вращения) просто за регистрацию, без необходимости вносить свои собственные средства. Это отличная возможность познакомиться с игрой, протестировать новые слоты или стратегии, и даже выиграть реальные деньги, не потратив ни копейки. Идеально для тех, кто только начинает свой путь в мире азартных игр или хочет попробовать что-то новое без финансовых обязательств.

  37. nightglowon8zef Avatar
    nightglowon8zef

    Je suis bluffe par Betify Casino, il cree un monde de sensations fortes. La bibliotheque de jeux est captivante, offrant des experiences de casino en direct. Il donne un elan excitant. Le suivi est toujours au top. Le processus est transparent et rapide, bien que plus de promotions variees ajouteraient du fun. Pour conclure, Betify Casino offre une experience hors du commun. Notons aussi le site est rapide et style, ce qui rend chaque partie plus fun. Egalement genial le programme VIP avec des recompenses exclusives, assure des transactions fiables.
    Entrer sur le site|

  38. JerryAmure Avatar
    JerryAmure

    DrMedsAdvisor medication in mexico mexico pharmacy

  39. Curtisvax Avatar
    Curtisvax

    india pharmacy: doctor recommended Indian pharmacy – india pharmacy

  40. Robertinvok Avatar
    Robertinvok

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

  41. JerryAmure Avatar
    JerryAmure

    trusted Canadian generics canadian pharmacy canadian pharmacy reviews

Leave a Reply

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