Apabila beralih daripada pustaka mysql kepada PDO, anda mungkin menghadapi keperluan untuk melepaskan rentetan seperti yang anda pernah lakukan dengan real_escape_string. Dalam PDO, anda boleh memanfaatkan pendekatan yang lebih selamat dan cekap.
PDO menyediakan kaedah prepare(), yang membolehkan anda melaksanakan pertanyaan berparameter. Parametrisasi membantu mencegah serangan suntikan SQL dengan membersihkan input pengguna sebelum melaksanakan pernyataan SQL. Ia juga mengoptimumkan prestasi dengan menyimpan cache pelan pertanyaan, menghapuskan keperluan untuk petikan rentetan manual.
Untuk melepaskan petikan tunggal menggunakan PDO::prepare(), ikut langkah berikut:
Sediakan pernyataan:
$stmt = $pdo->prepare("INSERT INTO table (column) VALUES (:value)");
Ikat parameter:
$stmt->bindParam(':value', $escapedValue);
Laksanakan kenyataan:
$stmt->execute();
Dalam ini contoh, :value ialah pemegang tempat untuk nilai yang dilepaskan, yang boleh anda tetapkan menggunakan bindParam(). Pemacu PDO secara automatik akan mengendalikan melepaskan petikan tunggal untuk anda.
Dengan menggunakan PDO::prepare() untuk pengikatan parameter, anda boleh mencapai manfaat keselamatan dan prestasi sambil menghapuskan keperluan untuk rentetan manual melarikan diri. Ini adalah amalan yang disyorkan dalam aplikasi PDO untuk menghalang suntikan SQL dan mengoptimumkan interaksi pangkalan data.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melarikan Diri dengan Selamat daripada Rentetan dalam PDO Tanpa Menggunakan `mysql_real_escape_string`?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!