Jump to content

Recommended Posts

I have a login script that checks for a correct username and password from a flat-file database. I was using preg_match, but I realized stripos should do the same thing but much faster.

 

And I was wondering if this can be exploited in anyway. I tried a combination of things, but they weren't successful.

 

public function check_login($u, $p) {

$p = md5($p);

$pos = stripos(file_get_contents($this->users_db), "{$u}:{$p}*");

if($pos !== false) return true; else return false;

}

 

Flatfile db

<?PHP die(); ?>*
lol:9cdfb439c7876e703e307864c9167a15*
test:098f6bcd4621d373cade4e832627b4f6*
admin:21232f297a57a5a743894a0e4a801fc3*

 

Thanks for the time!

 

 

 

Link to comment
https://forums.phpfreaks.com/topic/155301-can-this-be-exploited/
Share on other sites

Are you asking if it's safe? I would say probably yes.

 

I would recommend defining a constant in the file you want this flatfile to run through though; then check if the constant isn't defined in the file, and kill the script if it is. That will prevent people from accessing it without your specific script.

 

Script to run though:

<?php
define ('HeLLoPeOpLzZ', 1);
?>

 

 

flatfile:

<?php
if ( !defined('HeLLoPeOpLzZ') )
die ('');
?>

 

I think that's what you intend with the die() function, but I don't really understand how that works in your situation.

The reason why I asked if it could be exploited, well not exploited, but made things to that it shouldn't is because its not regex (less control). And I just found one...

 

Take this line for example: lol:9cdfb439c7876e703e307864c9167a15*

By the way md5("lol") equals "9cdfb439c7876e703e307864c9167a15"

 

If you enter "ol" as username and "lol" as password, you still get entered as user "lol".

 

Can anyone help with a solution (without using regex)?

 

Now that I think about it, it is not terrible that it does that since if there was a user called "ol" he would have a different password anyways. But if they somehow ended up with same passwords, all these users have same privileges. However, I still like for it to somehow be solved. Thank you!

its not safe

 

if u understand how strpos works.

 

Use delimeterd around yer strings

instead of

{$u}:{$p}*

use something like

\x01{$u}:{$p}*

 

now \x01 will be treated as a special character, CTRL-A, which u shudn be able to enter by keyboard.

 

or ya can use \n which is a newline, which is how lines end in the text file :)

but that means first line, ya either have a comment, or leave it empty

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.