Rumah > pembangunan bahagian belakang > tutorial php > Bagaimanakah Saya Boleh Mencegah Serangan Traversal Direktori dalam PHP Semasa Membenarkan Laluan Relatif?

Bagaimanakah Saya Boleh Mencegah Serangan Traversal Direktori dalam PHP Semasa Membenarkan Laluan Relatif?

Patricia Arquette
Lepaskan: 2024-12-07 16:13:12
asal
968 orang telah melayarinya

How Can I Prevent Directory Traversal Attacks in PHP While Allowing Relative Paths?

Menghalang Direktori Traversal sambil Membenarkan Laluan dalam PHP

Apabila bekerja dengan laluan relatif, adalah penting untuk melindungi daripada serangan traversal direktori yang boleh menjejaskan maklumat sistem sensitif.

Pertimbangkan senario di mana anda mempunyai laluan asas '/whatever/foo/' dan perlu membenarkan laluan relatif menggunakan pembolehubah $_GET['path']. Walau bagaimanapun, pelakon yang berniat jahat boleh cuba mengeksploitasi mekanisme ini dengan menyuntik urutan lintasan laluan (seperti '..' atau './') untuk mengakses direktori terhad.

Untuk mencegah traversal direktori dengan berkesan sambil membenarkan laluan relatif, anda boleh gunakan teknik berikut:

$basepath = '/foo/bar/baz/';
$realBase = realpath($basepath);

$userpath = $basepath . $_GET['path'];
$realUserPath = realpath($userpath);

if ($realUserPath === false || strpos($realUserPath, $realBase) !== 0) {
    // Directory Traversal Attempt Detected
} else {
    // Valid Path
}
Salin selepas log masuk

Kaedah ini memanfaatkan fungsi realpath() untuk menentukan fizikal mutlak laluan kedua-dua laluan asas dan yang disediakan pengguna. Dengan membandingkan laluan mutlak ini, anda boleh mengesahkan bahawa laluan pengguna tidak melintasi luar laluan asas yang ditetapkan. Jika ya, realpath() akan mengembalikan false atau laluan yang salah, mencetuskan pengesanan percubaan melintasi direktori.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencegah Serangan Traversal Direktori dalam PHP Semasa Membenarkan Laluan Relatif?. 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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan