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

10,114 responses to “Input validation with filter functions”

  1. Rayfordpag Avatar
    Rayfordpag

    prednisone buy without prescription: buy prednisone online usa – prednisone prescription drug

  2. GichardMam Avatar
    GichardMam

    Across Seoul, Gyeonggi, and Incheon, Maxim Anma offers a high-quality mobile massage service. Professional therapists visit your location to provide comfortable, personalized care including Thai, aroma, and Swedish treatments. Accessible anytime with a reliable post-payment system and complete privacy protection, providing a convenient and easy wellness experience whenever you need it.
    출장안마

  3. KevinBup Avatar
    KevinBup

    buy prednisone no prescription: generic prednisone tablets – prednisone 10mg tablets

  4. Rayfordpag Avatar
    Rayfordpag

    prednisone 1mg purchase: buy prednisone online usa – prednisone 12 mg

  5. GichardMam Avatar
    GichardMam

    Hey there! I understand this is sort of off-topic but I needed to ask. Does operating a well-established blog such as yours take a massive amount work? I’m completely new to running a blog however I do write in my diary every day. I’d like to start a blog so I can easily share my experience and thoughts online. Please let me know if you have any kind of suggestions or tips for new aspiring bloggers. Thankyou!

    гей порно онлайн

  6. KevinBup Avatar
    KevinBup

    amoxicillin capsules online: bacterial infection medication – fast delivery amoxicillin usa

  7. KevinBup Avatar
    KevinBup

    amoxil fast: bacterial infection medication – amoxicillin capsules online

  8. RobertGaurl Avatar

    BlackSprut marketplace официальный сайт для входа и регистрации
    blsp at bs2best at

    bs2 market

  9. KeithDep Avatar
    KeithDep

    http://ivermectinfast.com/# ivermectin treatment tablets

  10. Rayfordpag Avatar
    Rayfordpag

    where can i buy prednisone without a prescription: anti-inflammatory medication online – over the counter prednisone cream

  11. Herberthab Avatar

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

  12. PatrickHic Avatar

    провайдеры домашнего интернета домашний интернет от мегафона тарифы

  13. Allendwems Avatar
    Allendwems

    https://stericarepharmacy.com/# average cost of prednisone

  14. KeithDep Avatar
    KeithDep

    http://stericarepharmacy.com/# prednisone 20mg for sale

  15. StephenGlona Avatar
    StephenGlona

    Hey there, You’ve done a great job. I’ll definitely digg it and personally recommend to my friends. I’m sure they will be benefited from this web site.
    гача гей порно

  16. Rayfordpag Avatar
    Rayfordpag

    ivermectin fast: ivermectin 3mg tablets – trusted ivermectin pharmacy

  17. RobertGaurl Avatar

    BlackSprut marketplace официальный сайт для входа и регистрации
    blsp at bs2best at

    bs2web at

  18. KevinBup Avatar
    KevinBup

    prednisone cost in india: trusted steroid medication source – 1 mg prednisone daily

  19. Fobertsax Avatar
    Fobertsax

    Hey I know this is off topic but I was wondering if you knew of any widgets I could add to my blog that automatically tweet my newest twitter updates. I’ve been looking for a plug-in like this for quite some time and was hoping maybe you would have some experience with something like this. Please let me know if you run into anything. I truly enjoy reading your blog and I look forward to your new updates.
    детское гей порно

  20. KeithDep Avatar
    KeithDep

    http://stericarepharmacy.com/# prednisone 30 mg tablet

  21. Rayfordpag Avatar
    Rayfordpag

    generic ivermectin online pharmacy: trusted ivermectin pharmacy – trusted ivermectin pharmacy

  22. KevinBup Avatar
    KevinBup

    generic ivermectin online pharmacy: parasite infection medication – trusted ivermectin pharmacy

  23. Allendwems Avatar
    Allendwems

    https://amoxilfast.com/# amoxicillin 500 mg without prescription

  24. KevinBup Avatar
    KevinBup

    prednisone 5 mg tablet price: prednisone without prescription usa – buying prednisone on line

  25. Allendwems Avatar
    Allendwems

    http://stericarepharmacy.com/# prednisone 2.5 mg price

  26. RobertGaurl Avatar

    BlackSprut marketplace официальный сайт для входа и регистрации
    blsp at bs2best at

    bs2best вход

  27. Rayfordpag Avatar
    Rayfordpag

    2.5 mg prednisone daily: buy prednisone online usa – prednisone 3 tablets daily

  28. LhaneDrync Avatar
    LhaneDrync

    Very good site you have here but I was wanting to know if you knew of any community forums that cover the same topics talked about in this article? I’d really love to be a part of online community where I can get feed-back from other experienced people that share the same interest. If you have any suggestions, please let me know. Cheers!
    гей порно мультики

  29. ShaneEnacy Avatar

    разработка чат бота в max разработка мобильного приложения под ключ

  30. ShaneDrync Avatar
    ShaneDrync

    Today, I went to the beachfront with my children. I found a sea shell and gave it to my 4 year old daughter and said “You can hear the ocean if you put this to your ear.” She placed the shell to her ear and screamed. There was a hermit crab inside and it pinched her ear. She never wants to go back! LoL I know this is totally off topic but I had to tell someone!
    ебля жесткая

  31. RobertGaurl Avatar

    BlackSprut marketplace официальный сайт для входа и регистрации
    blsp at bs2best at

    blsp at

  32. LewisGuatt Avatar
    LewisGuatt

    WOW just what I was searching for. Came here by searching for %meta_keyword%
    тгк зоо порно

  33. Rayfordpag Avatar
    Rayfordpag

    trusted ivermectin pharmacy: stromectol without prescription usa – ivermectin treatment tablets

  34. BarryHus Avatar
    BarryHus

    prednisone online sale: prednisone uk – can you buy prednisone over the counter uk

  35. KeithDep Avatar
    KeithDep

    https://ivermectinfast.shop/# stromectol delivery united states

  36. KeithDep Avatar
    KeithDep

    https://amoxilfast.com/# amoxil 500mg tablets usa

  37. BarryHus Avatar
    BarryHus

    buy prednisone without rx: steroid tablets usa pharmacy – buy prednisone online without a script

  38. KevinBup Avatar
    KevinBup

    fast delivery amoxicillin usa: generic amoxicillin online – bacterial infection medication

  39. KeithDep Avatar
    KeithDep

    https://ivermectinfast.shop/# stromectol delivery united states

  40. KevinBup Avatar
    KevinBup

    prednisone 2 mg daily: corticosteroid medication online – prednisone online pharmacy

  41. Rayfordpag Avatar
    Rayfordpag

    amoxil 500mg tablets usa: amoxacillian without a percription – amoxil without prescription usa

  42. KevinBup Avatar
    KevinBup

    amoxil 500mg tablets usa: buy amoxil online usa – buy amoxil online usa

  43. RobertGaurl Avatar

    BlackSprut marketplace официальный сайт для входа и регистрации
    blsp at bs2best at

    blsp сайт

  44. BarryHus Avatar
    BarryHus

    price of prednisone tablets: trusted steroid medication source – prednisone without prescription

  45. Rayfordpag Avatar
    Rayfordpag

    ivermectin treatment tablets: Stromectol – antiparasitic medication usa

Leave a Reply

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