• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Brak reakcji bazy danych

Object Storage Arubacloud
0 głosów
150 wizyt
pytanie zadane 29 listopada 2017 w PHP przez prymex Obywatel (1,250 p.)

Cześć mam kod php i do tego oczywiście formularz i męczę się już 2 dni i nie mogę znaleźć błędu :

Normalnie kod php się wykonuje ale nie wstawia rekordu do bazy danych, ale baza też działa pod względem że bez pośrednio na bazie da się wstawić rekord:

 

<?php

session_start();

if (isset($_POST['email']))
{
$wszystko_OK=true;

$login = $_POST['login'];

if ((strlen($login)<3) || (strlen($login)>20))
{
$wszystko_OK=false;
$_SESSION['e_nick']="Nick musi posiadać od 3 do 20 znaków!";
}

if (ctype_alnum($login)==false)
{
$wszystko_OK=false;
$_SESSION['e_nick']="Nick może składać się tylko z liter i cyfr (bez polskich znaków)";
}

$email = $_POST['email'];
$emailB = filter_var($email, FILTER_SANITIZE_EMAIL);

if ((filter_var($emailB, FILTER_VALIDATE_EMAIL)==false) || ($emailB!=$email))
{
$wszystko_OK=false;
$_SESSION['e_email']="Podaj poprawny adres e-mail!";
}

    
$password1 = $_POST['password1'];
$password2 = $_POST['password2'];

if ((strlen($password1)<8) || (strlen($password1)>20))
{
$wszystko_OK=false;
$_SESSION['e_haslo']="Hasło musi posiadać od 8 do 20 znaków!";
}

if ($password1!=$password2)
{
$wszystko_OK=false;
$_SESSION['e_haslo']="Podane hasła nie są identyczne!";
}	

$password_hash = password_hash($password1, PASSWORD_DEFAULT);

$connect = new PDO('mysql:host=localhost;dbname=blogi', 'root', '');


    $result_email = $connect->prepare("SELECT id FROM uzytkownicy WHERE email=:email");
	$result_email->bindValue(':email', $email);
	
	
    $count_email = $result_email->rowCount();
    if($count_email>0)
    {
        $wszystko_OK=false;
        $_SESSION['e_email']="Istnieje już konto przypisane do tego adresu e-mail!";
    }		

    $result_login = $connect->prepare("SELECT id FROM uzytkownicy WHERE login=:login");
   	$result_login->bindValue(':login', $login);

    $count_login = $result_login->rowCount();
    if($count_login>0)
    {
        $wszystko_OK=false;
        $_SESSION['e_nick']="Istnieje już gracz o takim nicku! Wybierz inny.";
    }

    if ($wszystko_OK==true)
    {

		$user = $connect->Prepare("INSERT INTO uzytkownicy VALUES (NULL, :login, :email, :password_hash)");
		$user->bindValue(':login', $login);
		$user->bindValue(':email', $email);
		$user->bindValue(':password_hash', $password_hash);
    }

}

?>

 

komentarz 29 listopada 2017 przez CzikaCarry Szeryf (75,340 p.)
Chyba poraz pierwszy widzę, że ktoś na forum wstawia pytanie i korzysta z PDO. Miło, że świat zmienia się na lepsze :)
komentarz 30 listopada 2017 przez prymex Obywatel (1,250 p.)
Tak to prawda, cały czas chce brnąć z nauką do przodu. Aktualnie właśnie używam PDO które nie jest takie złe. :D, Myślę że inni też powinni cały czas rozwijać swoją wiedzę (podejście) programistyczne .

2 odpowiedzi

0 głosów
odpowiedź 29 listopada 2017 przez Arkadiusz Waluk Ekspert (287,950 p.)
Zapomniałeś dodać execute(), aby cokolwiek się wykonało.
komentarz 29 listopada 2017 przez prymex Obywatel (1,250 p.)
Faktycznie, dziękuję za pomoc . Pozdrawiam :)
0 głosów
odpowiedź 29 listopada 2017 przez Ehlert Ekspert (212,790 p.)

Proponuję:

$connect->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

i kod z pdo ująć w try...catch. 

Podobne pytania

0 głosów
0 odpowiedzi 81 wizyt
pytanie zadane 23 sierpnia 2016 w JavaScript przez Bakr Mądrala (6,850 p.)
0 głosów
2 odpowiedzi 208 wizyt
pytanie zadane 5 grudnia 2015 w PHP przez meegi Nowicjusz (160 p.)
0 głosów
3 odpowiedzi 1,505 wizyt
pytanie zadane 26 października 2016 w HTML i CSS przez Lukash4k1 Nowicjusz (120 p.)

92,615 zapytań

141,465 odpowiedzi

319,779 komentarzy

61,997 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...