"إذا أراد العامل أن يؤدي عمله بشكل جيد، فعليه أولاً أن يشحذ أدواته." - كونفوشيوس، "مختارات كونفوشيوس. لو لينجونج"
الصفحة الأمامية > برمجة > هل أحتاج إلى `mysql_real_escape_string()` مع البيانات المعدة؟

هل أحتاج إلى `mysql_real_escape_string()` مع البيانات المعدة؟

تم النشر بتاريخ 2024-11-18
تصفح:420

Do I Need `mysql_real_escape_string()` with Prepared Statements?

هل وظيفة mysql_real_escape_string() مطلوبة مع البيانات المعدة؟

عند استخدام البيانات المعدة كما في الاستعلام المحدد:

$sql = $db->prepare('select location from location_job where location like ?');

$sql->bind_param('s', $consulta);
$sql->execute();
$sql->bind_result($location);

وظيفة mysql_real_escape_string() ليست ضرورية لأن البيانات المعدة توفر طريقة آمنة لمنع هجمات حقن SQL عن طريق الهروب من أي أحرف خاصة داخل الإدخال.

أحد الاقتراحات لتحسين الاستعلام هو استخدام "؟" العنصر النائب، مما يتيح لك تمرير المعلمات بشكل أكثر سهولة من خلال طريقة التنفيذ:

$sql->execute([$consulta]);

ومع ذلك، تأكد من تنظيف إدخال المستخدم باستخدام htmlspecialchars () قبل عرضه لمنع ثغرات البرمجة النصية عبر المواقع.

أحدث البرنامج التعليمي أكثر>

تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.

Copyright© 2022 湘ICP备2022001581号-3