セキュリティテストプロジェクトのためにローカルホスト上に作成されたダミーのWebサイトでSQLインジェクションを実行しようとしています。
" OR "='
ユーザー名とパスワードのフィールドに文字列を入力しようとしたので、それをバイパスしてログインを正しく表示する必要があります-しかし、代わりにログインに失敗したと表示されます
SQLインジェクションが機能しない理由を理解するためのヘルプ
<?php
mysql_connect('localhost', 'root', '');
mysql_select_db('test');
if(isset($_POST['username'])&&isset($_POST['password'])){
$username =$_POST['username'];
$password = $_POST['password'];
echo $username;
echo $password;
if(!empty($username)&&!empty($password)){
$query ="SELECT id FROM users WHERE username = '$username' AND password = '$password'";
$query_run = mysql_query($query);
if(mysql_num_rows($query_run)>=1){
echo 'Login Correct';
}else{
echo 'Login Failed';
}
}
}
?>
<form action="test.php" method="POST">
Username: <input type="text" name="username">
Password: <input type="text" name="password">
<input type="submit" value="Submit">
</form>