Samouczek PHP

Strona główna PHP Wprowadzenie do PHP Instalacja PHP Składnia PHP Komentarze PHP Zmienne PHP PHP Echo / Drukuj Typy danych PHP Ciągi PHP Liczby PHP Matematyka w PHP Stałe PHP Operatory PHP PHP Jeśli...Inne...Elseif Przełącznik PHP Pętle PHP Funkcje PHP Tablice PHP PHP Superglobals PHP RegEx

Formularze PHP

Obsługa formularzy PHP Walidacja formularzy PHP Wymagany formularz PHP Adres URL/e-mail formularza PHP Formularz PHP kompletny

Zaawansowany PHP

Data i godzina w PHP Uwzględnij PHP Obsługa plików PHP Otwórz/odczytaj plik PHP Tworzenie/zapisywanie plików PHP Przesyłanie plików PHP Pliki cookie PHP Sesje PHP Filtry PHP Zaawansowane filtry PHP Funkcje wywołania zwrotnego PHP PHP JSON Wyjątki PHP

PHP OOP

PHP Co to jest OOP Klasy/obiekty PHP Konstruktor PHP Destruktor PHP Modyfikatory dostępu PHP Dziedziczenie PHP Stałe PHP Klasy abstrakcyjne PHP Interfejsy PHP Cechy PHP Metody statyczne PHP Właściwości statyczne PHP Przestrzenie nazw PHP Iterowalne PHP

Baza danych MySQL

Baza danych MySQL Połączenie MySQL Tworzenie bazy danych MySQL Utwórz tabelę MySQL Wstaw dane MySQL Pobierz ostatni identyfikator MySQL Wstaw wiele MySQL Przygotowano MySQL Wybierz dane MySQL MySQL Gdzie Zamów MySQL według Usuń dane MySQL Dane aktualizacji MySQL Dane limitu MySQL

PHP XML

Parsery PHP XML Parser PHP SimpleXML PHP SimpleXML — Get Rozszerzenie PHP XML PHP XML DOM

PHP - AJAX

Wprowadzenie do AJAX AJAX PHP Baza danych AJAX XML AJAX Wyszukiwanie na żywo AJAX Ankieta AJAX

Przykłady PHP

Przykłady PHP Kompilator PHP Quiz PHP Ćwiczenia PHP Certyfikat PHP

Odniesienie do PHP

Przegląd PHP Tablica PHP Kalendarz PHP Data PHP Katalog PHP Błąd PHP Wyjątek PHP System plików PHP Filtr PHP PHP FTP PHP JSON Słowa kluczowe PHP Biblioteka PHP Poczta PHP Matematyka w PHP Różne PHP PHP MySQLi Sieć PHP Kontrola wyjścia PHP PHP RegEx PHP SimpleXML Strumień PHP ciąg PHP Obsługa zmiennych PHP Parser PHP XML Kod pocztowy PHP Strefy czasowe PHP

Przygotowane wyciągi PHP MySQL


Przygotowane instrukcje są bardzo przydatne w przypadku wstrzyknięć SQL.


Przygotowane oświadczenia i powiązane parametry

Przygotowana instrukcja to funkcja używana do wielokrotnego wykonywania tych samych (lub podobnych) instrukcji SQL z wysoką wydajnością.

Przygotowane zestawienia działają w zasadzie tak:

  1. Przygotuj: tworzony jest szablon instrukcji SQL i wysyłany do bazy danych. Niektóre wartości pozostają nieokreślone, nazywane parametrami (oznaczone „?”). Przykład: INSERT INTO MyGuests VALUES (?, ?, ?)
  2. Baza danych analizuje, kompiluje i przeprowadza optymalizację zapytań w szablonie instrukcji SQL i przechowuje wynik bez jego wykonywania
  3. Wykonaj: w późniejszym czasie aplikacja wiąże wartości z parametrami, a baza danych wykonuje instrukcję. Aplikacja może wykonać instrukcję tyle razy, ile chce z różnymi wartościami

W porównaniu z bezpośrednim wykonywaniem instrukcji SQL, przygotowane instrukcje mają trzy główne zalety:

  • Przygotowane instrukcje skracają czas parsowania, ponieważ przygotowanie zapytania jest wykonywane tylko raz (chociaż instrukcja jest wykonywana wielokrotnie)
  • Powiązane parametry minimalizują przepustowość do serwera, ponieważ za każdym razem musisz wysyłać tylko parametry, a nie całe zapytanie
  • Przygotowane instrukcje są bardzo przydatne w przypadku wstrzyknięć SQL, ponieważ wartości parametrów, które są przesyłane później przy użyciu innego protokołu, nie muszą być poprawnie escapowane. Jeśli oryginalny szablon instrukcji nie pochodzi z danych wejściowych zewnętrznych, nie można wykonać wstrzyknięcia SQL.

Przygotowane oświadczenia w MySQLi

Poniższy przykład używa przygotowanych instrukcji i powiązanych parametrów w MySQLi:

Przykład (MySQLi z przygotowanymi instrukcjami)

<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);

// Check connection
if ($conn->connect_error) {
  die("Connection failed: " . $conn->connect_error);
}

// prepare and bind
$stmt = $conn->prepare("INSERT INTO MyGuests (firstname, lastname, email) VALUES (?, ?, ?)");
$stmt->bind_param("sss", $firstname, $lastname, $email);

// set parameters and execute
$firstname = "John";
$lastname = "Doe";
$email = "[email protected]";
$stmt->execute();

$firstname = "Mary";
$lastname = "Moe";
$email = "[email protected]";
$stmt->execute();

$firstname = "Julie";
$lastname = "Dooley";
$email = "[email protected]";
$stmt->execute();

echo "New records created successfully";

$stmt->close();
$conn->close();
?>

Linie kodu do wyjaśnienia z powyższego przykładu:

"INSERT INTO MyGuests (firstname, lastname, email) VALUES (?, ?, ?)"

W naszym SQL wstawiamy znak zapytania (?), w którym chcemy podstawić wartość całkowitą, łańcuchową, podwójną lub blob.

Następnie spójrz na funkcję bind_param():

$stmt->bind_param("sss", $firstname, $lastname, $email);

Ta funkcja wiąże parametry z zapytaniem SQL i informuje bazę danych, jakie są parametry. Argument „sss” wymienia typy danych, którymi są parametry. Znak s mówi mysql, że parametr jest łańcuchem.

Argument może być jednym z czterech typów:

  • ja - liczba całkowita
  • d - podwójne
  • s - ciąg
  • b - BLOB

Musimy mieć jeden z nich dla każdego parametru.

Mówiąc mysql jakiego typu danych ma się spodziewać, minimalizujemy ryzyko iniekcji SQL.

Uwaga: jeśli chcemy wstawić jakiekolwiek dane ze źródeł zewnętrznych (takich jak dane wprowadzone przez użytkownika), bardzo ważne jest, aby dane zostały oczyszczone i zweryfikowane.



Przygotowane oświadczenia w PDO

Poniższy przykład używa przygotowanych instrukcji i powiązanych parametrów w PDO:

Przykład (PDO z przygotowanymi oświadczeniami)

<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDBPDO";

try {
  $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
  // set the PDO error mode to exception
  $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

  // prepare sql and bind parameters
  $stmt = $conn->prepare("INSERT INTO MyGuests (firstname, lastname, email)
  VALUES (:firstname, :lastname, :email)");
  $stmt->bindParam(':firstname', $firstname);
  $stmt->bindParam(':lastname', $lastname);
  $stmt->bindParam(':email', $email);

  // insert a row
  $firstname = "John";
  $lastname = "Doe";
  $email = "[email protected]";
  $stmt->execute();

  // insert another row
  $firstname = "Mary";
  $lastname = "Moe";
  $email = "[email protected]";
  $stmt->execute();

  // insert another row
  $firstname = "Julie";
  $lastname = "Dooley";
  $email = "[email protected]";
  $stmt->execute();

  echo "New records created successfully";
} catch(PDOException $e) {
  echo "Error: " . $e->getMessage();
}
$conn = null;
?>