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

Rejestracja w php - błąd Uncaught Error: Call to undefined method mysqli::error()

Object Storage Arubacloud
0 głosów
469 wizyt
pytanie zadane 26 września 2020 w PHP przez mn130496 Gaduła (3,530 p.)

Witam

Ostatnio zacząłem naukę  programowania w języku php. Na podstawie filmu Pana Mirosława zelanta  napisałem taki skrypt rejestracji:

<?php
    session_start();
    if(isset($_POST['email']))
    {
        $udana_walidacja = true;

        //Walidacja loginu 

        $login = $_POST['login'];

        //Sprawdzanie długości loginu
        if( (strlen($login) < 3) || (strlen($login) > 20) )
        {
            $udana_walidacja = false;
            $_SESSION['e_login'] = "Login musi posiadać od 3 do 20 znaków";
        }

        //Sprawdzanie czy login składa się z znaków alfanumerycznych bez polskich znaków
        if(ctype_alnum($login) == FALSE)
        {
            $udana_walidacja = FALSE;
            $_SESSION['e_login'] = "Login musi składać się ze znaków alfanumerycznych (bez polskich znaków)! ";
        } 
        
        //Walidacja emaila

        $email = $_POST['email'];
		$emailB = filter_var($email, FILTER_SANITIZE_EMAIL);
		
		if ((filter_var($emailB, FILTER_VALIDATE_EMAIL)==false) || ($emailB!=$email))
		{
			$udana_walidacja = FALSE;
			$_SESSION['e_email']="Podaj poprawny adres e-mail!";
        } 
        
        //Walidacja hasła
        
        $haslo1 = $_POST['haslo1'];
        $haslo2 = $_POST['haslo2'];

        //Sprawdzanie czy hasła są takie same

       //Sprawdzanie długości hasła
       if((strlen($haslo1) < 8 ) || (strlen($haslo1) > 20 ))
       {
           $udana_walidacja = FALSE;
           $_SESSION['e_haslo'] = "Hasło musi posiadać od 8 do 20 znaków!";
       }

       // Sprawdzanie czy podane hasła są identyczne
       if($haslo1 != $haslo2)
       {
        $udana_walidacja = FALSE;
        $_SESSION['e_haslo'] = "Podane hasła różnią się";
       }

       // Sprawdzanie czy hasło posiada przynajmniej jedną wielką literę i przynajmniej 1 znak specjalny 

       if(!preg_match('@[A-Z]@', $haslo1))
       {
        $udana_walidacja = FALSE;
        $_SESSION['e_haslo'] = "Hasło musi posiadać przynajmniej 1 dużą literę  i znaki specjalne";
       } 
       
       // haszowanie hasła

       $haslo_hasz = $haslo_hash = password_hash($haslo1, PASSWORD_DEFAULT);

       //Sprawdzenie czy zaakceptowano regulamin 

      if(!isset($_POST['regulamin']))
       {
        {
            $udana_walidacja = FALSE;
            $_SESSION['e_regulamin'] = "Zaakceptuj regulamin! ";
        }
       }

       //Sprawdzenie czy recaptcha jest zaznaczona

       $sekret = "6LdZitAZAAAAAK2dIek6DMo78L8Rc-5hCq-1TBLg";
		
		$sprawdz = file_get_contents('https://www.google.com/recaptcha/api/siteverify?secret='.$sekret.'&response='.$_POST['g-recaptcha-response']);
		
		$odpowiedz = json_decode($sprawdz);
		
		if ($odpowiedz->success==false)
		{
			$udana_walidacja=false;
			$_SESSION['e_bot']="Potwierdź, że nie jesteś botem!";
		}	$kod = md5(mt_rand());

		
		//łączenie z bazą
		require_once "connect.php";
		mysqli_report(MYSQLI_REPORT_STRICT);
		try
		{
			$polaczenie = new mysqli($host,$db_user,$db_password,$db_name);
            if($polaczenie->connect_errno !=0)
            {
                throw new EXCEPTION(mysqli_connect_errno());
			}
			else
			{
				$rezultat = $polaczenie->query("SELECT id FROM uzytkownicy WHERE email='$email'");
				
				if (!$rezultat) throw new Exception($polaczenie->error);
				$ile_takich_maili = $rezultat->num_rows;
				if($ile_takich_maili>0)
				{
					$udana_walidacja = FALSE;
					$_SESSION['e_email']="Istnieje już konto przypisane do tego adresu e-mail!";
				} 
				$rezultat = $polaczenie->query("SELECT id FROM uzytkownicy WHERE user='$login'");
				
				if (!$rezultat) throw new Exception($polaczenie->error);
				$ile_takich_loginow = $rezultat->num_rows;
				if($ile_takich_loginow>0)
				{
					$udana_walidacja = FALSE;
                    $_SESSION['e_login']="Istnieje już użytkownik o takim loginie , Wybież inny login !";
                    
                }

                if($udana_walidacja == TRUE)
                {
					if($polaczenie -> query("INSERT INTO uzytkownicy VALUES (NULL , '$login','$haslo_hash','$email')"))
                    {
                        $_SESSION['udanarejestracja']=true;
                        header('Location: witamy.php');
                    }else {
                        throw new Exception ($polaczenie -> error());
                    }
                }   
                $polaczenie -> close(); 
			}
		}
		catch(Exception $e)
		{
			echo '<span style="color:red;">Błąd serwera! Przepraszamy za niedogodności i prosimy o rejestrację w innym terminie!</span>';
			echo '<br />Informacja developerska: '.$e;
		}

        
    }
?>

 

problem polega na tym , że gdy prubuje zarejestrować konto to wyskakuje mi błąd:

Fatal error: Uncaught Error: Call to undefined method mysqli::error() in /opt/lampp/htdocs/kurs_php/strona/rejestracja.php:133 Stack trace: #0 {main} thrown in /opt/lampp/htdocs/kurs_php/strona/rejestracja.php on line 133. linia 133 to throw new Exception ($polaczenie -> error());.

Czy ktoś może mi powiedzieć dlaczego mi wyskakuje ten błąd , czy ma to coś wspólnego z tym , że używam wersji php 7.4.10 i w tej wersji nie są wspierane funkcje mysqli czy chodzi ocoś innego?

z góry dziękuję

1 odpowiedź

+1 głos
odpowiedź 26 września 2020 przez Arkadiusz Waluk Ekspert (287,950 p.)
wybrane 27 września 2020 przez mn130496
 
Najlepsza
throw new Exception ($polaczenie -> error());

Obiekt klasy mysqli nie ma metody error, a ma właściwość error. Powinno więc być $polaczenie->error, a nie $polaczenie->error().

Prawdopodobnie to nie jedyny błąd, bo skoro przeszedł do rzucania wyjątku to coś musiało pójść nie tak. Jak poprawisz wyciąganie błędu bazy to powinien pokazać co.

1
komentarz 27 września 2020 przez mn130496 Gaduła (3,530 p.)
dziękuję za pomoc poprawiłem i wszystko działa jak należy

Podobne pytania

0 głosów
1 odpowiedź 640 wizyt
0 głosów
0 odpowiedzi 737 wizyt
0 głosów
3 odpowiedzi 5,559 wizyt

92,575 zapytań

141,424 odpowiedzi

319,649 komentarzy

61,960 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!

...