Rumah > pembangunan bahagian belakang > tutorial php > Cara Menggunakan Kad Liar dengan Penyata Disediakan PDO: Panduan untuk Mengelakkan Perangkap Biasa?

Cara Menggunakan Kad Liar dengan Penyata Disediakan PDO: Panduan untuk Mengelakkan Perangkap Biasa?

DDD
Lepaskan: 2024-10-28 13:52:01
asal
330 orang telah melayarinya

How to Use Wildcards with PDO Prepared Statements: A Guide to Avoiding Common Pitfalls?

Penyata Disediakan PDO dengan Sokongan Wildcard

Penyata yang disediakan menawarkan keselamatan dan prestasi yang dipertingkatkan untuk pertanyaan pangkalan data dengan menghalang serangan suntikan SQL. Walau bagaimanapun, menggunakan kad bebas dengan pernyataan yang disediakan boleh menimbulkan cabaran.

Dalam kes anda, anda cuba melaksanakan pertanyaan seperti:

<code class="sql">SELECT * FROM `gc_users` WHERE `name` LIKE '%anyname%'</code>
Salin selepas log masuk

Anda cuba mengikat parameter dengan '%:name Kaedah %' dan ':name', tetapi kedua-duanya gagal. Begini cara anda boleh menggunakan kad bebas dengan pernyataan yang disediakan:

Menggunakan bindValue:

Anda boleh menggunakan bindValue untuk mengikat parameter kad bebas dengan betul:

<code class="php">$stmt = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` LIKE :name");
$stmt->bindValue(':name', '%' . $name . '%');
$stmt->execute();</code>
Salin selepas log masuk

Menggunakan bindParam (Diubah suai):

Selain itu, anda juga boleh menggunakan bindParam dengan sedikit pengubahsuaian:

<code class="php">$name = "%$name%";
$query = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` like :name");
$query->bindParam(':name', $name);
$query->execute();</code>
Salin selepas log masuk

Atas ialah kandungan terperinci Cara Menggunakan Kad Liar dengan Penyata Disediakan PDO: Panduan untuk Mengelakkan Perangkap Biasa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan