Solved

comparing security question values

Posted on 2006-07-13
7
224 Views
Last Modified: 2011-08-18
on my login page i ask the member to enter there username,password and answer a simple security question.

but each time i keep getting the error page...


$numbers = array();
      
      $numbers[1] = 'one';
      $numbers[2] = 'two';
      $numbers[3] = 'three';
      $numbers[4] = 'four';
      $numbers[5] = 'five';
      
      $first = array_rand($numbers);
      $second = array_rand($numbers);
      
<form name="loginFrm" method="post" action="'.$_SERVER['PHP_SELF'].'" >
      <input type="hidden" value="'.time().'" name="currenttime">'."\n";
      <input type="hidden" value="'.md5($first+$second+time()).'" name="sum">'."\n";
      Username:<input type="text" name="username">
      Password:<input type="password" name="password">
Security Question:What is '.$numbers[$first].' plus '.$numbers[$second].'? <input type="text" name="answer" size="2" value="">
<input type="submit" value="Login">
</form>


$s_Username .= trim($_POST['username']);
$s_Password .= trim($_POST['password']);
      
$s_Answer .= trim($_POST['answer']);
$s_CurrentTime .= trim($_POST['currenttime']);
      
$s_SumAnswer = md5($s_Answer+$s_CurrentTime);
$s_Sum .= trim($_POST['sum']);
      
if($s_Sum == $s_SumAnswer)
{      
                  //Problems with answer to security question
}
else
{
    // check username and password
    if ok
        login them in
    else
        ///problems
}
0
Comment
Question by:ellandrd
  • 4
  • 3
7 Comments
 
LVL 54

Accepted Solution

by:
b0lsc0tt earned 500 total points
ID: 17104235
ellandrd,

If I understand correctly the problem is occurring when you are trying to match $s_Sum and $s_SumAnswer.  Am I correct that they are not matching?

I think the problem is the sum.  In the form a person has only 2 spaces so would put the number (e.g. 9).  However it looks like your sum would be the two numbers as words concatenated (e.g. fourfive).

Let me know if you have any question or need more information.  If I misunderstood the problem please clarify what the error is and where it occurs.

b0lsc0tt
0
 
LVL 54

Expert Comment

by:b0lsc0tt
ID: 17104262
It looks like a person would go to the section "//Problems with answer to security question" if $s_Sum and $s_sumAnswer are equal.  I assumed that was a typo and that they should go to that section if the variables are NOT equal.  If that is the way your code is then that may also be a problem.
0
 
LVL 16

Author Comment

by:ellandrd
ID: 17104328
>>If I understand correctly the problem is occurring when you are trying to match $s_Sum and $s_SumAnswer.  Am I >>correct that they are not matching?

yes


>>I think the problem is the sum.  In the form a person has only 2 spaces so would put the number (e.g. 9).  However it >>looks like your sum would be the two numbers as words concatenated (e.g. fourfive).

ah ha!  let me change it...


0
Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

 
LVL 16

Author Comment

by:ellandrd
ID: 17104375
still no working...

can you help?
0
 
LVL 54

Expert Comment

by:b0lsc0tt
ID: 17104481
Have you tried to print each variable?  I would also print the type for each variable.  You could use this code and copy it immediately above the If statement.

echo "Sum is " . $s_Sum . "<br>\n";
echo "Type is " . gettype($s_Sum) . "<br>\n";
echo "SumAnswer is " . $s_SumAnswer . "<br>\n";
echo "Type is " . gettype($s_SumAnswer) . "<br>\n";

What are the results?  Just to clarify what is happening, if the 2 variables are equal then it goes to "//Problems" section?  What situation are you testing (i.e. correct answer to security question or incorrect answer) and which part of the If statement are they going to?  Thanks for clarifying that for me.
0
 
LVL 54

Expert Comment

by:b0lsc0tt
ID: 17104494
I guess that the problem is fixed since you have accepted my comment.  Thank you for the grade, the points and the fun question.  If you care to reply I am interested to hear what happened after you replied that it still was not working.

bol
0
 
LVL 16

Author Comment

by:ellandrd
ID: 17104631
oh i had another typo in my variable...

have another here if interested...

http://www.experts-exchange.com/Web/Web_Languages/PHP/Q_21918903.html
0

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Popularity Can Be Measured Sometimes we deal with questions of popularity, and we need a way to collect opinions from our clients.  This article shows a simple teaching example of how we might elect a favorite color by letting our clients vote for …
Foreword (July, 2015) Since I first wrote this article, years ago, a great many more people have begun using the internet.  They are coming online from every part of the globe, learning, reading, shopping and spending money at an ever-increasing ra…
Explain concepts important to validation of email addresses with regular expressions. Applies to most languages/tools that uses regular expressions. Consider email address RFCs: Look at HTML5 form input element (with type=email) regex pattern: T…
This tutorial will teach you the core code needed to finalize the addition of a watermark to your image. The viewer will use a small PHP class to learn and create a watermark.

837 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question