Dalam pengaturcaraan, selalunya perlu untuk berinteraksi secara dinamik dengan jadual pangkalan data. Sebagai contoh, anda mungkin ingin menjana input borang berdasarkan lajur jadual tertentu. Menggunakan PHP PDO, anda mungkin mempertimbangkan untuk mengikat nama jadual pada pertanyaan untuk mendapatkan butiran lajur.
Walau bagaimanapun, pendekatan ini menimbulkan risiko keselamatan. Mengikat nama jadual membolehkan pengguna mengakses mana-mana jadual dalam pangkalan data anda, yang berpotensi mendedahkan maklumat sensitif. Sebaliknya, adalah penting untuk menyenarai putih nama jadual yang dibenarkan dan menggunakan pendekatan yang lebih selamat.
Satu penyelesaian yang disyorkan ialah mencipta kelas asas abstrak untuk jadual pangkalan data, seperti abstractTable. Kelas ini boleh termasuk fungsi biasa, seperti sifat untuk memegang nama jadual dan kaedah untuk mendapatkan butiran lajur.
Kelas seterusnya boleh mewarisi daripada kelas asas ini dan menentukan nama jadual khusus mereka. Sebagai contoh, anda boleh mencipta kelas someTable yang memanjangkan abstractTable dan menetapkan sifat jadualnya kepada 'sometable'.
Menggunakan pendekatan ini, anda boleh mendapatkan semula butiran lajur untuk jadual tertentu dengan selamat:
$pdo = new PDO(...); $table = new someTable($pdo); $fields = $table->describe();
Kaedah ini lebih selamat, kerana ia mengehadkan akses kepada hanya jadual yang disenarai putih dan menghalang pengguna daripada mengakses jadual sewenang-wenang dalam pangkalan data anda.
Atas ialah kandungan terperinci Bolehkah anda mengikat nama jadual dalam pertanyaan PHP PDO?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!