Jump to content
¯\_( ツ)_/¯
  • TAD GROUP are currently hiring penetration testers. Please read the topic in Career Central subforum.
  • Sponsored Ad
Sign in to follow this  
LinuxMaster

SQL Injection атака поправки

Recommended Posts

Интродукция

 

SQL Injector е техника за инжектиране на код който се използва за атака. Тя позволява да вземеш информацията на една база данни. Първите признаци за уязвимост се появяват когато потребителят който използва SQL Injection въведе знаци които не могат да се филтрират правилно.

 

Нека да речем, че нашият сайт има страница

http://localhost/news.php?id=3

Първото нещо което трябва да направя аз като тест е да добавя знак ' след id=3 

http://localhost/news.php?id=3'

И ако нашият сайт е уязвим на такъв вид атака то ще ни излезе съобщение със следната информация 

Error : You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '\'' at line 

Как да се предпазиме от такъв вид атаки?
Да речем, че това е нашият код

<?php 
if(isset($_GET['id'])){
    // danni ot news
    $sel = mysql_query("SELECT * FROM news WHERE id = '".$_GET['id']."'"); 
        $row = mysql_fetch_array($sel);
}
?>

Ако сме задали променливата id то тогава ще изберем всичко от news с това id, но след като добавиме още една кавичка след id = '".$_GET['id']."' то целият код ще даде една перфектна грешка за един хакер да проникне в нашата система.

За да оправиме този проблем, към нашият код трябва да добавим, че искаме да се въвеждат само цифри(is_numeric) което автоматично ще ни предпази от следваща SQL атака

<?php 
    if(isset($_GET['id']) && is_numeric($_GET['id'])){
        // danni ot news
        $sel = mysql_query("SELECT * FROM news WHERE id = '".$_GET['id']."'"); 
            $row = mysql_fetch_array($sel);
    }
?>

 

 

  • Like 1

Share this post


Link to post
Share on other sites

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.   Paste as plain text instead

  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.

Sign in to follow this  

  • Recently Browsing   0 members

    No registered users viewing this page.

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use. 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.