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

5,963 responses to “Input validation with filter functions”

  1. Taylorsmump Avatar
    Taylorsmump

    http://vetfreemeds.com/# online pet pharmacy

  2. Taylorsmump Avatar
    Taylorsmump

    http://certicanpharmacy.com/# canadian pharmacy com

  3. Edwardtom Avatar
    Edwardtom

    best canadian online pharmacy: CertiCanPharmacy – CertiCanPharmacy

  4. Larryfig Avatar
    Larryfig

    pet meds online online pet pharmacy canada pet meds

  5. Taylorsmump Avatar
    Taylorsmump

    https://mymexicanpharmacy.com/# mexican online pharmacy wegovy

  6. ThomasUplic Avatar

    вентиляция квартиры приточной установкой с фильтром Наши специалисты выполняют установку вентиляции любой сложности, с учетом всех норм и пожеланий клиента.

  7. DiegoMog Avatar
    DiegoMog

    My Mexican Pharmacy: My Mexican Pharmacy – can i order online from a mexican pharmacy

  8. MichaelKek Avatar
    MichaelKek

    http://vetfreemeds.com/# pet prescriptions online

  9. MichaelKek Avatar
    MichaelKek

    https://mymexicanpharmacy.com/# My Mexican Pharmacy

  10. Larryfig Avatar
    Larryfig

    п»їdog medication online pet prescriptions online vet pharmacy online

  11. Taylorsmump Avatar
    Taylorsmump

    https://vetfreemeds.com/# online pet pharmacy

  12. Taylorsmump Avatar
    Taylorsmump
  13. Edwardtom Avatar
    Edwardtom

    My Mexican Pharmacy: My Mexican Pharmacy – mexican pharma

  14. DiegoMog Avatar
    DiegoMog

    CertiCanPharmacy: the canadian pharmacy – certified canadian pharmacy

  15. MichaelKek Avatar
    MichaelKek
  16. DiegoMog Avatar
    DiegoMog

    vet pharmacy online: canada pet meds – pet med

  17. Taylorsmump Avatar
    Taylorsmump

    https://vetfreemeds.com/# online vet pharmacy

  18. MichaelKek Avatar
    MichaelKek

    http://vetfreemeds.com/# discount pet meds

  19. RonaldCrido Avatar

    Навигация на https://cipollinopizza.ru интуитивная, всё разложено по полочкам.

  20. Edwardtom Avatar
    Edwardtom

    pet meds for dogs: п»їdog medication online – dog prescriptions online

  21. Larryfig Avatar
    Larryfig

    online pet pharmacy pet drugs online dog medicine

  22. Taylorsmump Avatar
    Taylorsmump

    http://vetfreemeds.com/# discount pet meds

  23. Taylorsmump Avatar
    Taylorsmump

    https://certicanpharmacy.com/# online canadian drugstore

  24. Edwardtom Avatar
    Edwardtom

    My Mexican Pharmacy: My Mexican Pharmacy – My Mexican Pharmacy

  25. DiegoMog Avatar
    DiegoMog

    dog prescriptions online: online vet pharmacy – online vet pharmacy

  26. RonaldCrido Avatar

    Программа лояльности на https://vympel-kino.ru выгодная, кэшбэк и персональные бонусы.

  27. MichaelKek Avatar
    MichaelKek

    https://vetfreemeds.com/# pet prescriptions online

  28. Taylorsmump Avatar
    Taylorsmump

    https://mymexicanpharmacy.com/# pharmacys in mexico

  29. RonaldCrido Avatar

    Amatic на https://postpredstvo15.ru для ностальгии, простые слоты.

  30. Kevinphype Avatar

    анонимные знакомства Мелитополь Мечтаете о новых встречах и ярких эмоциях?

  31. Larryfig Avatar
    Larryfig

    legitimate canadian mail order pharmacy CertiCanPharmacy CertiCanPharmacy

  32. Edwardtom Avatar
    Edwardtom

    pet med: VetFree Meds – pet pharmacy online

  33. DiegoMog Avatar
    DiegoMog

    pet rx: VetFree Meds – pet drugs online

  34. MichaelKek Avatar
    MichaelKek

    https://certicanpharmacy.com/# canadian drug pharmacy

  35. Edwardtom Avatar
    Edwardtom

    canadian pharmacy scam: CertiCanPharmacy – canada drugstore pharmacy rx

  36. Taylorsmump Avatar
    Taylorsmump

    https://vetfreemeds.com/# online vet pharmacy

  37. Terryfacle Avatar

    заказать аудиорекламу Доверьте заказ аудиорекламы экспертам – гарантируем рост продаж и лояльность.

  38. DiegoMog Avatar
    DiegoMog

    CertiCanPharmacy: canadian neighbor pharmacy – CertiCanPharmacy

  39. Robertamevy Avatar

    интернет магазин лазерных принтеров (Лазерный принтер – идеальное решение для быстрой и четкой печати документов. | Лазерные принтеры превосходят струйные по скорости и экономии тонера. | Хотите лазерный принтер купить? Широкий выбор моделей по доступным ценам! | Лазерные принтеры купить легко в нашем магазине с гарантией качества. | Купить лазерный принтер – значит инвестировать в надежность и производительность. | Заказать лазерный принтер онлайн – быстро и без лишних хлопот. | Лазерный принтер цена радует: от 5000 руб. за базовые модели. | Узнайте лазерный принтер стоимость – выгодные акции для всех покупателей. | Ищете лазерный принтер недорого? У нас лучшие предложения! | Лазерный принтер купить недорого – реальность с нашими скидками до 30%. | Дешевый лазерный принтер не уступает по качеству печати. | Бюджетный лазерный принтер для дома и офиса – оптимальный выбор. | Лазерный принтер купить онлайн в 2 клика с доставкой. | Заказать лазерный принтер онлайн – удобный сервис 24/7. | Лазерный принтер интернет магазин с тысячами отзывов. | Интернет магазин лазерных принтеров – ваш надежный партнер. | Лазерный принтер каталог: фото, характеристики, отзывы. | Лазерный принтер в наличии – забирайте сегодня! | Лазерный принтер с доставкой по России бесплатно от 5000 руб.)

  40. RonaldCrido Avatar

    Big Time Gaming на https://kidradar.ru с механиками, мегавейсы заходят.

  41. Larryfig Avatar
    Larryfig

    pet pharmacy VetFree Meds pet drugs online

Leave a Reply

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