Walaupun mysql_real_escape_string menawarkan cara untuk melepaskan pertanyaan MySQL dan menghalang suntikan SQL, adalah disyorkan untuk menggunakan Objek Data PHP (PDO ) untuk keselamatan dan serba boleh dipertingkatkan.
PDO ialah antara muka berorientasikan objek dalam PHP yang menyediakan pendekatan bersatu untuk berinteraksi dengan pelayan pangkalan data yang berbeza. Ia merangkum operasi pangkalan data biasa ke dalam kaedah dan sifat objek, memudahkan pengendalian pangkalan data.
1. Melarikan diri: PDO secara automatik melepaskan nilai input berdasarkan enjin pangkalan data yang digunakan. Ini membantu menghalang suntikan SQL, yang mana input berniat jahat boleh menjejaskan pangkalan data anda.
2. Pertanyaan Berparameter: PDO menyokong pertanyaan berparameter, membolehkan anda mengikat nilai pada ruang letak dalam pernyataan SQL anda. Ini menghalang manipulasi parameter pertanyaan secara tidak sengaja atau sengaja, meningkatkan lagi keselamatan.
3. Kebebasan Pangkalan Data: PDO boleh menyambung ke pelbagai pelayan pangkalan data (cth., MySQL, PostgreSQL, Oracle). Dengan hanya mengubah suai rentetan sambungan, anda boleh bertukar antara pangkalan data dengan lancar tanpa mengubah kod anda.
4. Reka Bentuk Berorientasikan Objek: PDO adalah berorientasikan objek, yang mengikut amalan pengaturcaraan terbaik. Ia membolehkan anda mencipta objek sambungan pangkalan data boleh guna semula dan mengendalikan operasi pangkalan data dengan lebih kawalan dan modulariti.
Untuk menggunakan PDO untuk MySQL melarikan diri, ikut langkah berikut:
Sambung ke Pangkalan Data:
<code class="php">$dsn = 'mysql:dbname=mydb;host=localhost'; $user = 'username'; $password = 'password'; $pdo = new PDO($dsn, $user, $password);</code>
Sediakan Pertanyaan:
<code class="php">$query = $pdo->prepare('SELECT * FROM users WHERE username = :username');</code>
Ikat Parameter:
<code class="php">$query->bindParam(':username', $username);</code>
Laksanakan Pertanyaan:
<code class="php">$query->execute();</code>
Dapatkan Keputusan:
<code class="php">$results = $query->fetchAll(PDO::FETCH_ASSOC);</code>
Dengan menggunakan PDO, anda memanfaatkan mekanisme yang teguh dan selamat untuk melarikan diri dari pertanyaan MySQL dan berinteraksi dengan pangkalan data anda.
Atas ialah kandungan terperinci Bila Menggunakan PDO Over mysql_real_escape_string untuk Melarikan Diri Pertanyaan MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!