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,576 responses to “Input validation with filter functions”

  1. FelixHoult Avatar

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

  2. RobertMumma Avatar

    MHFA Pharm: MhfaPharm – canadian 24 hour pharmacy

  3. RichardFap Avatar
    RichardFap

    canadian pharmacy phone number http://uvapharm.com/# UvaPharm

  4. RichardFap Avatar
    RichardFap

    onlinepharmaciescanada com http://mhfapharm.com/# MHFA Pharm

  5. RobertMumma Avatar

    IsoIndiaPharm: IsoIndiaPharm – Iso Pharm

  6. Hunteramato Avatar

    mexican pharmacy prices: hydrocodone mexico pharmacy – prescriptions from mexico

  7. Hunteramato Avatar

    IsoIndiaPharm: india pharmacy – IsoIndiaPharm

  8. Timsothydet Avatar
    Timsothydet

    Thanks , I have just been searching for info approximately this topic for a while and yours is the best I have found out till now. However, what concerning the bottom line? Are you positive concerning the source?
    Escort directory listing Rio

  9. RobertMumma Avatar

    MHFA Pharm: MHFA Pharm – MHFA Pharm

  10. RichardFap Avatar
    RichardFap

    canadapharmacyonline https://isoindiapharm.com/# IsoIndiaPharm

  11. ForestKef Avatar

    IsoIndiaPharm india pharmacy IsoIndiaPharm

  12. Horacelab Avatar

    Zooma казино Зума Казино – это не просто платформа для удовлетворения азартных желаний, а тщательно выстроенная экосистема развлечений, где каждый элемент направлен на создание максимально комфортной и захватывающей атмосферы. Мы предлагаем не просто игры, а возможность погрузиться в мир ярких эмоций, стратегического мышления и, конечно же, шанс испытать удачу и сорвать куш. Разнообразие игровых автоматов, карточных игр, рулеток и лайв-казино с профессиональными дилерами обеспечивает бесконечный поток впечатлений и не даст заскучать даже самым искушенным игрокам. Зума официальный канал – это ваш личный проводник в захватывающий мир Зума Казино. Подписывайтесь и будьте в курсе эксклюзивных акций, турниров с крупными призовыми фондами, анонсов новых игр и полезных советов от экспертов. Мы делимся секретами успешной игры, анализируем стратегии и помогаем вам принимать взвешенные решения, чтобы увеличить ваши шансы на выигрыш. Зума – это не только азарт, но и ответственность. Мы придерживаемся принципов честной игры и обеспечиваем безопасную среду для наших пользователей. Современные технологии шифрования гарантируют защиту ваших персональных данных и финансовых транзакций. Мы работаем в соответствии с международными стандартами лицензирования и всегда готовы оказать поддержку и ответить на любые вопросы. Zooma казино – это ваш портал в мир больших возможностей. Играйте в любое время и в любом месте, наслаждаясь удобным интерфейсом и плавной работой на любом устройстве. Мы постоянно работаем над улучшением нашего сервиса, чтобы предоставить вам лучший игровой опыт. Присоединяйтесь к миллионам игроков по всему миру и откройте для себя мир Зума Казино, где азарт встречается с возможностью стать победителем!

  13. RichardFap Avatar
    RichardFap

    canadian pharmacy store https://isoindiapharm.xyz/# IsoIndiaPharm

  14. ForestKef Avatar

    MHFA Pharm MhfaPharm MhfaPharm

  15. RobertMumma Avatar

    Iso Pharm: Iso Pharm – IsoIndiaPharm

  16. RobertMumma Avatar

    UvaPharm: Uva Pharm – order from mexico

  17. RichardFap Avatar
    RichardFap

    canada pharmacy online https://isoindiapharm.xyz/# Iso Pharm

  18. Dereklaunk Avatar
    Dereklaunk

    Reviewed sources offering best trading signals demonstrate legit trading expertise. Join telegram groups with trustworthy alpha insights, best buy and sell timing, and trusted Trustpilot verification through trading community feedback.

  19. Stevengor Avatar
    Stevengor

    Budget-conscious players can buy cheap robux through larger bundles. Bulk purchasing options offer improved value per Robux compared to smaller denominations reducing cost for substantial amounts.

  20. RichardFap Avatar
    RichardFap

    canadian pharmacy 365 https://isoindiapharm.xyz/# pharmacy website india

  21. Scottarown Avatar

    центр для пожилых Геронтологический центр – это не просто медицинское учреждение, это комплексный подход к поддержанию здоровья и активного долголетия пожилых людей. Здесь не только лечат болезни, связанные с возрастом, но и создают условия для полноценной жизни, наполненной общением, творчеством и заботой. Это место, где старость – не приговор, а новый этап жизни.

  22. RobertMumma Avatar

    mexican drug store: Uva Pharm – pharmacy in mexico that ships to us

  23. RobertMumma Avatar

    purple pharmacy online ordering: Uva Pharm – Uva Pharm

  24. RichardFap Avatar
    RichardFap

    reputable canadian online pharmacy https://mhfapharm.xyz/# reddit canadian pharmacy

  25. Kod Binance Avatar

    I don’t think the title of your article matches the content lol. Just kidding, mainly because I had some doubts after reading the article.

  26. RichardFap Avatar
    RichardFap

    the canadian pharmacy http://isoindiapharm.com/# top 10 online pharmacy in india

  27. ForestKef Avatar

    Iso Pharm IsoIndiaPharm buy prescription drugs from india

  28. RobertMumma Avatar

    farmacia online usa: mexican pharmacy prices – UvaPharm

  29. Scottarown Avatar

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

  30. RichardFap Avatar
    RichardFap

    canadian compounding pharmacy http://uvapharm.com/# can i order online from a mexican pharmacy

  31. ForestKef Avatar

    IsoIndiaPharm Iso Pharm best online pharmacy india

  32. Patricklib Avatar
    Patricklib

    top 10 pharmacies in india https://socalabortionpill.xyz/# buy cytotec online

  33. Charlescliny Avatar

    SocalAbortionPill: Abortion pills online – Socal Abortion Pill

  34. Jamesbourf Avatar

    1xbet промокод при регистрации Получите промокод на https://ar29.ru/pars/doms/1xbet-promokod-pri-registracii-besplatno.html и получите бонус 100% на первый депозит при регистрации для комфортной игры.

  35. DouglasJag Avatar

    Socal Abortion Pill: buy abortion pills – buy cytotec over the counter

  36. Patricklib Avatar
    Patricklib

    top 10 pharmacies in india http://pmaivermectin.com/# PmaIvermectin

Leave a Reply

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