Mengapa REGISTER_GLOBALS menjadi Ancaman dalam PHP?
Dalam PHP, tetapan REGISTER_GLOBALS membolehkan semua pembolehubah melalui input web (GET atau POST) untuk menjadi tersedia secara automatik sebagai pembolehubah global. Ciri ini mungkin kelihatan mudah, tetapi ia boleh mendatangkan malapetaka pada aplikasi PHP.
Mari kita teliti sebab REGISTER_GLOBALS menimbulkan ancaman besar:
1. Kebolehcapaian Pembolehubah Yang Tidak Diinginkan:
Dengan menjadikan pembolehubah input web global, REGISTER_GLOBALS secara tidak sengaja memberikan akses kepada pembolehubah yang sepatutnya tertutup atau terhad. Penyerang boleh memanipulasi pembolehubah ini untuk mengakses data sensitif atau melaksanakan kod hasad, yang membawa kepada pelanggaran keselamatan yang serius.
2. Isu Pembolehubah Tidak Diisytiharkan:
PHP mengendalikan pembolehubah yang tidak diisytiharkan sebagai amaran, bukan ralat. Ini bermakna kod dengan REGISTER_GLOBALS didayakan boleh mengakses pembolehubah input web walaupun ia tidak ditakrifkan secara eksplisit dalam skrip. Ini boleh membawa kepada tingkah laku yang tidak dijangka dan potensi risiko keselamatan.
3. Kerentanan Kod:
Kod PHP yang direka bentuk dengan buruk selalunya menghasilkan amaran pembolehubah yang tidak dimulakan. Dengan REGISTER_GLOBALS didayakan, amaran ini boleh mendedahkan maklumat sensitif tentang keadaan aplikasi, membantu penyerang dalam usaha mereka untuk mengeksploitasi kelemahan.
Contoh: Penyahpepijatan Tidak Wajar
Pertimbangkan PHP berikut kod dengan REGISTER_GLOBALS didayakan:
<code class="php">// $debug = true; if ($debug) { echo "query: $query\n"; }</code>
Dalam senario ini, pembolehubah $query belum diisytiharkan secara eksplisit. Jika permintaan web menyertakan pembolehubah bernama pertanyaan dalam parameter GET atau POSTnya, REGISTER_GLOBALS akan menjadikannya tersedia sebagai pembolehubah global dan ia akan digemakan tanpa sekatan. Ini boleh menyebabkan maklumat sensitif, seperti pertanyaan SQL, dibocorkan.
Walaupun REGISTER_GLOBALS mungkin kelihatan mudah, risiko keselamatannya jauh melebihi faedah yang dirasakannya. Aplikasi PHP yang direka dengan baik tidak seharusnya bergantung padanya dan sebaliknya menumpukan pada pengisytiharan pembolehubah eksplisit dan pematuhan ketat kepada amalan keselamatan terbaik.
Atas ialah kandungan terperinci Mengapa REGISTER_GLOBALS Ancaman Keselamatan dalam Aplikasi PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!