繁体   English   中英

创建用于sql注入的演示时出现sql语法错误

[英]sql syntax error while creating a demo for sql injection

我正在尝试创建一个登录页面以演示轻度的SQL注入攻击。 以下是从login.html接收输入的php代码:

<?php 
define('DB_HOST', 'localhost'); 
define('DB_NAME', 'sql-injection'); 
define('DB_USER','root'); 
define('DB_PASSWORD',''); 
$con=@mysql_connect(DB_HOST,DB_USER,DB_PASSWORD) or die("Failed to connect to MySQL: " . mysql_error()); 
$db=mysql_select_db(DB_NAME,$con) or die("Failed to connect to MySQL: " . mysql_error()); 
/* $ID = $_POST['user']; $Password = $_POST['pass']; */ 

function SignIn() 
{ 
session_start(); //starting the session for user profile page 

if(!empty($_POST['user']) and !empty($_POST['pass'])) //checking the username and password which is coming from Sign-In.html, are they empty or have some text
 {      

        $query = mysql_query("SELECT * FROM UserName where userName = '$_POST[user]'") or die(mysql_error()); 

        $row = mysql_fetch_array($query) or die(mysql_error()); 

        if(!empty($row['userName']) AND !empty($row['pass'])) 
        { 
                if ($_POST['pass'] == $row['pass'])
                {
                    echo "SUCCESSFULLY LOGIN TO USER PROFILE PAGE...";
                }
                else
                {
                    echo "SORRY... YOU ENTERD WRONG ID AND PASSWORD... PLEASE RETRY..."; 
                }

        } 
        else 
        {   
                    echo "The db is corrupt";
        } 
} 
else{
    echo "The username and password fields cant be empty";
}
} 
if(isset($_POST['submit'])) 
{ 

SignIn(); 

} 

?>

该数据库具有一个带有列的表用户名

UsernameID userName   pass
1          mrboolnew  mrbool123

我正在尝试在用户名列中输入以下内容:

Y'; UPDATE用户名SET userName ='mrboolnew1'WHERE userName ='mrboolnew';

但我得到以下错误:

您的SQL语法有误; 检查与您的MySQL服务器版本相对应的手册,以在'UPDATE username SET userName ='mrboolnew1'WHERE userName ='mrboolnew';''附近使用正确的语法

有人可以帮我解决注射查询问题吗? 提前致谢。

您添加了保护措施,以防止注入攻击,甚至可能根本不知道mysql_query()仅向数据库发送一个查询(请参见此处 )。 不允许使用分号; 也不是多个查询。

您将不得不更加努力地注入自己的代码。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM