v2.5.2
Giriş yap

Php 3 kere yanlış giriş yapılırsa hata verdirme sorunu

yazilimyolcusu
809 defa görüntülendi ve 3 kişi tarafından değerlendirildi

Merhaba arkadaşlar. Kullanıcı, şifreyi 3 kez yanlış girerse hata verdirmeye çalışıyorum. Bunun içinde veritabanında "hataligirissayisi" diye bir alan açtım. Varsayılan değer olarak da "0" verdim. Aşağıdaki kod ile yapmak istediğim şu: Her yanlış giriş yaptığında veritabanında, o kullanıcıya ait "hataligirissayisi" alanı 1 artırmak istiyorum. Bunu da "insert" işlemi ile yapmaya çalışıyorum ama en aşağıdaki "giriş yapılamadı" uyarısı veriyor ve veritabanındaki "hataligirissayisi" alanına da ekleme yapamıyorum. Log kaydında hata yok. Sayfa da hata vermiyor.

<?php
if($_POST['kullanicigirisgonder']) {
        $kullaniciadi    = trim(strip_tags(base64_encode($_POST['kullanicigirisadi'])));
        $kullanicisifre  = trim(strip_tags(base64_encode($_POST['kullanicigirissifre'])));
        ?>
        

        <?php
        $girissorgusu  = "SELECT * FROM kullanicilar WHERE kullanicilar_kullaniciadi = '$kullaniciadi' AND kullanicilar_sifre = '$kullanicisifre'";
        $girissorgu    = mysqli_query($db, $girissorgusu);
        $sonuc = mysqli_fetch_array($girissorgu);

        
        if(($sonuc['kullanicilar_kullaniciadi'] == $kullaniciadi) AND ($sonuc['kullanicilar_sifre'] == $kullanicisifre)) {

            $_SESSION['adi']       = $sonuc;
            $_SESSION['sifresi']   = $sonuc;

            if(!empty($_POST['benihatirla'])) {
                $cerez = trim(strip_tags($_POST['benihatirla']));
                $cerezadi     = "kullanicicerezi";
                $cerezdegeri  = "kullanicicerezsifre";
                setcookie($cerezadi, $cerezdegeri, time() + (86400), "/"); // 86400 = 1 day
            } else {
                
            }

            header("Refresh:0; url=index.php");
        } elseif(($sonuc['kullanicilar_kullaniciadi'] == $kullaniciadi) AND ($sonuc['kullanicilar_sifre'] != $kullanicisifre)) {
            $girissorg  = "SELECT * FROM kullanicilar WHERE hataligirissayisi";
            $girissor    = mysqli_query($db, $girissorg);
            $say = mysqli_num_rows($girissor);
            $saydir = mysqli_fetch_num($girissor);

            for($x=3; $x >= $saydir['hataligirissayisi']; $x++) {

                $ekle = "INSERT INTO kullanicilar (hataligirissayisi) VALUES ('$x')";
                if(mysqli_query($db, $ekle)) {
                    echo "<center><h1>"."Bir Artırıldı."."</h1></center>"."<center><br><h1>"."Lütfen Tekrar Deneyiniz."."</h1></center>"."<center><br><h2>"."Giriş Sayfasına Yönlendiriliyorsunuz...</center>";
        }
    }
} else {
    echo "<center><img src='images/onayhataresimleri/unlem.png' style='width:50px; height:135px; margin-top:25px;'></center>";
    echo "<center><h1>"."Giriş Yapılamadı."."</h1></center>"."<center><br><h1>"."Lütfen Tekrar Deneyiniz."."</h1></center>"."<center><br><h2>"."Giriş Sayfasına Yönlendiriliyorsunuz...</center>";
    header("Refresh:4; url=giris-formu.php");
}
}
?>
zelemi
982 gün önce

Session da tutabilirsin ve session count yaparak eğer 3'ten büyük ise hata verdire bilirsin
veya daha kapsamlı yapıcam diyorsan db üzerinde giriş ip bilgisini tutatarak ta bu işlemi gerçekleştire bilirsin.