Rumah  >  Artikel  >  pangkalan data  >  Adakah mysql_real_escape_string() Terdedah kepada SQL Injection dengan Pengekodan Asia?

Adakah mysql_real_escape_string() Terdedah kepada SQL Injection dengan Pengekodan Asia?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-27 22:54:10716semak imbas

Is mysql_real_escape_string() Vulnerable to SQL Injection with Asian Encodings?

Menilai Keselamatan mysql_real_escape_string() terhadap SQL Injection dengan Asian Encodings

Soalan:

Kerentanan keselamatan telah dilaporkan mendakwa bahawa mysql_real_escape_string() boleh dipintas menggunakan pengekodan aksara Asia tertentu, seperti BIG5 atau GBK. Adakah kelemahan ini sah, dan jika ya, bagaimanakah kita boleh mengurangkannya tanpa menggunakan pernyataan yang disediakan?

Jawapan:

Menurut Stefan Esser, pembangun PHP, mysql_real_escape_string( ) tidak selamat sepenuhnya terhadap suntikan SQL apabila tetapan pengekodan tertentu digunakan.

Penjelasan:

Isu timbul apabila arahan SET NAMES digunakan untuk mengubah pengekodan aksara pangkalan data. Perubahan dalam pengekodan ini mempengaruhi cara aksara khas, seperti garis miring ke belakang (), dilarikan. Mysql_real_escape_string() menganggap pengekodan lalai dan tidak melaraskan logik melarikan diri dengan sewajarnya.

Oleh itu, jika penyerang menggunakan pengekodan yang membenarkan garis miring ke belakang sebagai bait berikutnya, mysql_real_escape_string() mungkin tidak melarikan diri dengan betul daripada aksara ini. Ini boleh membawa kepada serangan suntikan SQL yang berjaya.

Mitigasi:

Untuk menyelesaikan kelemahan ini apabila pernyataan yang disediakan tidak tersedia:

  1. Gunakan mysql_set_charset() berfungsi untuk menetapkan pengekodan aksara pangkalan data secara eksplisit dan bukannya bergantung pada SET NAMES. Ini memastikan bahawa mysql_real_escape_string() beroperasi dengan maklumat pengekodan yang betul.
  2. Tukar kepada pengekodan yang selamat, seperti UTF-8, yang mengendalikan garis miring ke belakang dengan cara yang menghalang penyalahgunaannya dalam suntikan SQL.

Atas ialah kandungan terperinci Adakah mysql_real_escape_string() Terdedah kepada SQL Injection dengan Pengekodan Asia?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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