PDA

View Full Version : Fast user authentification


squishi
09-25-2011, 09:33 AM
For a vb 3.8.x programming project, I need a page to load very quickly.
Loading the whole forum with
require("./global.php");
takes way too long, especially if there is a high load on the server.

So instead, I wanted to load the user's data (I only need the username!) using the cookie information.
The query would look like this:
SELECT u.username FROM vb_user as u,
vb_session as s
WHERE u.userid = '".mysql_real_escape_string($_COOKIE['vbuserid'])."'
AND u.password = '".mysql_real_escape_string($_COOKIE['vbpassword'])."'
AND s.sessionhash = '".mysql_real_escape_string($_COOKIE['vbsessionhash'])."'
LIMIT 1

The problem:
The hashed password in the cookie does not match the password that is stored in the database. I specifically checked it for my own account. The password in the cookie does not match the password in the vb_user table.

Why don't they match?

How else can I quickly authenticate a user without loading the whole forum?

kh99
09-25-2011, 12:53 PM
Why don't they match?

The password value in the cookie has been put through md5() once more, after being concatenated with the value of COOKIE_SALT (defined in includes/functions.php). So you'd want to do something like:

if (md5($password_from_db . COOKIE_SALT) == $password_from_cookie)
{
// password match
}


see function verify_authentication() includes/funtions_login.php.

souperman
09-27-2011, 11:00 PM
Kh99, is correct. Haven't check how vb salts its passwords, but they do add a salt to the password.

squishi
09-29-2011, 06:11 PM
Thanks, Kh99. That was helpful.