DoQtor N0 Posted February 4, 2011 Share Posted February 4, 2011 I am a newbie to php. Ran away from it from years but now I see the light! I am in the process of developing a web site application w/ MySql backend and I would like to do the following: 1. Client registers for my site. 2. How do I create code that validates password format to meet my password criteria (i.e. (2) capital letters, (2) special characters etc etc. Quote Link to comment https://forums.phpfreaks.com/topic/226706-password-validation/ Share on other sites More sharing options...
drisate Posted February 4, 2011 Share Posted February 4, 2011 <? function Check_Password($password) { //Makes it easy to implement grammar rules. $password_flaws = array(); $strlen = strlen($password); if($strlen <= 5) $password_flaws[sizeof($password_flaws)] = "too short"; $count_chars = count_chars($password, 3); if(strlen($count_chars) < $strlen / 2) $password_flaws[sizeof($password_flaws)] = "too simple"; //The function returns an empty string if the password is "good". $return_string = ""; $sizeof = sizeof($password_flaws); for($index = 0; $index < $sizeof; $index++) { if($index == 0) $return_string .= "the password is "; if($index == $sizeof - 1 && $sizeof != 1) $return_string .= " and "; //this is in case i have more than 3 sources of error. if($index != 0 && $index != $sizeof - 1) $return_string .= ", "; $return_string .= $password_flaws[$index]; } return($return_string); } ?> You can validate your password this way. Add in there any extra rules you may need. (don't over do it thought) Quote Link to comment https://forums.phpfreaks.com/topic/226706-password-validation/#findComment-1169955 Share on other sites More sharing options...
fortnox007 Posted February 4, 2011 Share Posted February 4, 2011 maybe also have a look in regex (regular expressions, whole section in the forum dedicated to it) it's a bit more advanced but i am pretty sure i needs less coding and might even be faster. Quote Link to comment https://forums.phpfreaks.com/topic/226706-password-validation/#findComment-1170023 Share on other sites More sharing options...
fortnox007 Posted February 4, 2011 Share Posted February 4, 2011 maybe try this out i used regular expresions for it. <body> <?php if (isset($_POST['submit'])&& !empty($_POST['password'])){ // simple check if pressed submit and value of password is not empty $password = $_POST['password']; //assign value of form value to php variable if(preg_match('~[A-Z]{2,}[a-z]{2,}[^a-zA-Z]{2,}~',$password)){ //atleast 2 uppercase 2 lowercase 2 special character or number echo 'nice password'; }else{ echo 'password must contain bla bla bla'; } }else{ echo 'enter a password'; //default message } ?> <form action="<?php echo htmlspecialchars($_SERVER['PHP_SELF']); ?>" method="post"> <input type="text" name="password" value="" /> <input type="submit" name="submit" value="submit" /> </form> </body> the nice thing about regular expression is is that you can also use them exactly the same in javascript to give some extra cool realtime validation (but that's just as an extra, never rely on client side validation) Quote Link to comment https://forums.phpfreaks.com/topic/226706-password-validation/#findComment-1170035 Share on other sites More sharing options...
fortnox007 Posted February 4, 2011 Share Posted February 4, 2011 maybe try this out i used regular expresions for it. <body> <?php if (isset($_POST['submit'])&& !empty($_POST['password'])){ // simple check if pressed submit and value of password is not empty $password = $_POST['password']; //assign value of form value to php variable if(preg_match('~[A-Z]{2,}[a-z]{2,}[^a-zA-Z]{2,}~',$password)){ //atleast 2 uppercase 2 lowercase 2 special character or number echo 'nice password'; }else{ echo 'password must contain bla bla bla'; } }else{ echo 'enter a password'; //default message } ?> <form action="<?php echo htmlspecialchars($_SERVER['PHP_SELF']); ?>" method="post"> <input type="text" name="password" value="" /> <input type="submit" name="submit" value="submit" /> </form> </body> the nice thing about regular expression is is that you can also use them exactly the same in javascript to give some extra cool realtime validation (but that's just as an extra, never rely on client side validation) there is a slight error in my regex because it reuires that exact order but i hope you get the idea. Quote Link to comment https://forums.phpfreaks.com/topic/226706-password-validation/#findComment-1170045 Share on other sites More sharing options...
fortnox007 Posted February 5, 2011 Share Posted February 5, 2011 you might want to look in the regex forum the right regex can be found there with thanks to Crayon Violent http://www.phpfreaks.com/forums/php-regex/feeling-a-little-stupid/ Quote Link to comment https://forums.phpfreaks.com/topic/226706-password-validation/#findComment-1170086 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.