AraKullanıcı girişiGezintiEn son ağ günlüğü gönderileri
Son yorumlar
En Çok OkunanlarKimler yeni
Bağlantılarİçerik paylaşımı |
"php.ini" Yapılandırmasıyla, Sitelerinizi Hacklenmelere Karşı KoruyunSon zamanlarda "RFI" (Remote File Include) tarzı yöntemlerle birçok hack olayı yaşanıyor birçok kişi bunların önlemini almakta çaresiz kalıyor ve bu yüzden gerek itibarlarından gerekse sitelerinden oluyorlar. "RFI" açıklarını engelleyemeyenler için bir döküman yazmaya karar verdim. Bu sayede "RFI" açığınız olsa bile en az zararla hatta "0" zararla nasıl kurtulacağınızı anlatacağım. Bu ayarlar sayesinde hem güvenliğinizi hem de performansınızı artırmış olacaksınız. "php[i].ini" yapılandırmasına geçmeden önce sunucumuzda bulunan klasör ve dosya izinlerini "chmod" doğru şekilde ayarlayalım. Genelde FTP programlarında dosya yada klasör üzerine "sağ click" yapılıp yada "file" seçeneğinden "Change Attributes ya da Properties / CHMOD" seçeneklerinden düzenleriz burada "permissions" altında yani izinler altında önerilenleri girmek en uygunudur. Klasörler için: 755 İzinleri bu şekilde ayarlamanız güvenlik için ilk adımı atmanıza yardımcı olur. "php.ini" yapılandırması: Eğer server admini iseniz yani root yetkilere sahipseniz bu ayarları serverda bulunan tüm siteler için yapabilirsiniz genellikle "/usr/local/Zend/etc/" , "/usr/local/lib/" altında bulunur "php.ini" dosyasını açarak düzenleyebilirsiniz veya "httpd.conf" dosyasının doğru yapılandırılmasıyla da olur. Daha sonra apache'ye restart atmanız gerekmektedir. Root değilseniz sadece kendi siteniz için yapmanız gerekiyorsa kök dizininizde (public_html) bir "php.ini" dosyası oluşturarak veya varolan "php.ini" dosyasının içerisine altta verdiğim kodları ekleyerek güvenliğinizi sağlayabilirsiniz. Fakat sitenizle aynı serverda bulunan diğer sitelerden kaynaklanan açıklardan yararlanan kişiler root olmayı başarırlarsa burada anlatılanlar yetersiz kalır, root olmayı başaramazlarsa ve sitenizin şifrelerini kaptırmazsanız güvendesinizdir. ***Altta anlattığım bilgiler iyi bir güvenlik için yapılması gerekenler olduğundan dolayı bunları uyguladıktan sonra bazı scriptlerinizin çalışması engellenmiş olabilir. Ama scriptin çalışmasını engelleyen değerleri iptal ederseniz script tekrar doğru şekilde çalışacaktır***
Şimdi gelelim "php.ini" yapılandırmasına: "disable_functions" (Güvenlik) "disable_functions" ile serverınızda birçok fonksiyonun çalışmasını engelleyebilirsiniz bu sayede sitenize inject edilen scriptler, sheller için güvenliğinizi almış olursunuz. Bu kadar fonksiyon fazla gelebilir ama iyi bir güvenlik için şart. Bu kadar sayıda devre dışı bırakılan fonksiyonlar ilk defa "eno7.org" adresinde verilmiştir. Önerilen: CODE: 1. Eğer bu kadar fonsiyonu devre dışı bırakmak fazla geldiyse alttaki gibi de ayarlayabilirsiniz bu da güvenliğiniz için yeterlidir: CODE: 1. ------------------------- "safe_mode" (Güvenlik) "Safe Mode" adından da anlaşılacağı gibi "Güvenli Mod" anlamına geliyor. "Safe Mode" genelde birçok serverda "Off" durumdadır ve bu da birçok tehlikeye davetiye çıkaran unsurlar arasında yer alır. "Güvenli Modu Açık" durumuna getirmek shellerin serverımızda istedikleri gibi dolaşmalarını, exploitlerin çalıştırılmasını ve komutların execute edilmelerini önler. Günümüzde "açık olan güvenlik modunu" kapalı duruma getiren scriptler mevcut fakat altta anlatılan önlemlerle bunun da önüne geçilebilir. Önerilen: CODE: 1. ------------------------- "register_globals" (Güvenlik ve Performans) php.ini dosyasında bulunan "post" "get" ile gönderilen değerlere kullanıcı adlarıyla ulaşılıp ulaşılamayacağını belirtir. Session, cookie değerlerini kendi adıyla tanımlayarak birer değişken olmasına neden olur. "Off" olarak ayarlanırsa bu gibi değerlere kendi tanımladığı şekilde ulaşılamaz. Önerilen: CODE: 1. ------------------------- "allow_url_fopen" (Güvenlik) "allow_url_fopen" default olarak "açık" şeklinde gelir ve bunun "on" açık olması "file_get_contents()", "include()", "require()" fonksiyonlar uzaktaki dosyaları da işlemesine olanak tanır. Bunlara verilen bilgiler hiçbir kontrolden geçirilmezse kritik güvenlik açıklarını sebep olur. Önerilen: CODE: 1. ------------------------- "allow_url_include" (Güvenlik) Bu değer kapalı yapıldığında "require" ve "include" ile uzaktan dosya çağırılması engellenmiş olur ve bu sayede büyük bir tehlikeden kurtulmuş olursunuz. Önerilen: CODE: 1. ------------------------- "display_errors" (Güvenlik) Bu seçenek sitenizin çalışmasında oluşacak bir hatayı tarayıcıya yansıtıp yansıtmayacağını belirler yani siteniz için diyelim bir forum veya portal kullanıyorsunuz ve bunların çalışması esnasında genelde "Fatal error: Call to undefined function get_header() in /home/vhosts/site.com/index.php on line 37" şeklinde benzeri hata görülür bunların gözükmesini engellemek için bu değeri kapalı duruma getirmek gerekir zira kötü niyetli kişiler sitenizin serverda bulunan tam yolunu öğrenmiş olurlar. Önerilen: CODE: 1. ------------------------- "cgi.force_redirect" (Güvenlik) Bu değer normalde "on" olarak gelir ve Windows sunucularında IIS, OmniHTTPD gibi buralarda kapatılması gerekir. Kendi sunucunuz için bu durum yoksa değiştirmenize gerek yoktur. Önerilen: CODE: 1. ------------------------- "magic_quotes_gpc" (Güvenlik ve Performans) Magic Quotes işlemi GET/POST yöntemiyle gelen Cookie datasını otomatikmen PHP script'e kaçırır. Önerilen bu değerin kapalı olmasıdır. Önerilen: CODE: 1. ------------------------- "magic_quotes_runtime" (Güvenlik ve Performans) Magic quotes çalışma sürecinde data oluşturur, SQL'den exec()'den, vb. Önerilen: CODE: 1. ------------------------- "magic_quotes_sybase" (Güvenlik ve Performans) Sybase-style magic quotes kullanır (Bunun yerine \' ' bununla '' kaçırır) Önerilen: CODE: 1. ------------------------- "session.use_trans_sid" (Güvenlik) Bu ayarı dikkatli ayarlayın, kullanıcı emaile aktif oturum ID'si içeren URL gönderebilir Önerilen: CODE: 1. ------------------------- "open_basedir" (Güvenlik) Burada belirttiğiniz bir dizin haricindeki dosyaları veya klasörleri görmeleri olanaksızdır yani sitenizde sadece dosyalar dizininin görüntülenmesini istiyorsanız böyle yapılır CODE: 1. veya hem dosyalar hem de resimlerin bulunduğu yerin gözükmesi için de böyle CODE: 1. bunlar haricindeki yerlerin görünmesi imkansızdır. Önerilen: CODE: 1. /resimler ve /dosyalar yazan yere görünmesini istediğiniz dizinleri belirtin. ------------------------- "safe_mode_exec_dir" (Güvenlik) Safe Mode açıkken bunu yaparsanız sadece belirttiğiniz dizinde işlem yapılmasına izin verirsiniz. Safe Mode kapalıyken burada belirttiğiniz dizinlerin dışında hiçbir dizinde işlem yapılamaz. "/home/vhosts/site.com/public_html/" yazan yere kendi dizininizi yazabilirsiniz. Böylece, diyelim "/etc" v.s dizininden herhangi birşey çalıştırmasına izin vermezsiniz. Önerilen: CODE: 1. "Safe Mode" yani "Güvenli Mod" açıkken yapılması tavsiye edilmez. Çünkü "safe mode" burada belirttiğiniz dizinde etkisiz kalacaktır. Güvenli Mod'un açık olması o dizinde işe yaramayacaktır. Güvenlik için, "Safe Mod" yani "Güvenli Mod" "off" kapalıyken kullanılması daha uygundur. ------------------------- "asp[i]_tags" (Güvenlik) ASP Style < % % > taglarına izin verilip verilmeyeceği belirlenir, kapalı duruma getirilmesi önerilir. Önerilen: CODE: 1. ------------------------- "session.hash_function" (Güvenlik) Oturumlar için Hash Fonksiyonu 0: MD5 (128 bits) Önerilen: CODE: 1. ------------------------- "session.hash_bits_per_character" (Güvenlik) Hash çevirirken her karakterde kaç bit saklansın 4 bits: 0-9, a-f Önerilen: CODE: 1. ------------------------- "expose_php" (Güvenlik) "expose_php" açık ise kapalı yapılması önerilir. Aksi takdirde PHP ile yaptığınız herşeyde sunucu tarafından PHP sürümü gibi bilgiler gösterilir. Hackerlar hatta Lamerlar bu bilgileri severler. Bunları engellemek için "off" konumuna getiriniz. Önerilen: CODE: 1. ------------------------- "html_errors" (Güvenlik) Bu değerin açık olması durumunda PHP tıklanabilir hata mesajları üretecektir. Kapalı olması güvenlik için önerilir. Önerilen: CODE: 1. ------------------------- "max_execution_time" (Güvenlik) Scriptinizi maksimum uygulamayı yürütme zamanı mesela kullanıcı bir linke tıkladı ve bu linkin açılması belirtilen saniyeden fazla olursa sayfa sitenizin serverda bulunduğu tam yolu göstererek hata verir. Bu hataların gözükmesi güvenlik açısından sakıncalıdır. 300 saniye yazan yeri istediğiniz zaman ile değiştirebilirsiniz. Önerilen: CODE: 1. ------------------------- "max_input_time" (Güvenlik) Scriptinizin aynı şekilde bir dataya ulaşmak için istek yolladığında maksimum geçen zaman Önerilen: CODE: 1. ------------------------- "ServerSignature" (Güvenlik ve Performans) "ServerSignature" sitenizde bulunmayan bir dosyanın bakılması durumunda bu sayfanın altında serverla ilgili bir bilgi yer alır ve bu da performansı düşürür ayrıca kötü niyetli kişiler serverla ilgili bir bilgi öğrenmiş olurlar. Önerilen: CODE: 1. ------------------------- "UseCanonicalName" (Performans) Bu ayarın açık olması Apache self-referencing URL oluşturduğunda Server ismi ve porttan oluşan bir çözülmüş isim kullanır. Önerilen: CODE: 1. ------------------------- "HostnameLookups" (Performans) "HostnameLookups" açık olması performansın düşmesine neden olur. IP numarası DNS sunucusundan bakılarak adres öğrenilir buda performansı düşürür. Önerilen: CODE: 1. ------------------------- "ExtendedStatus" (Performans) Serverın durumunu öğrenmek için server-status kullanılıyorsa Apache her an bu işlemcinin çağrılabileceğini beklediği için hazır bekler ve her an sistem saatini öğrenmesi gerekir bu da performansı düşürür. Önerilen: CODE: 1. ------------------------- "register_long_arrays" (Güvenlik ve Performans) Bu değerin "on" açık olması durumunda sisteminizde her script çalışmayacaktır install v.s yapmakta hatalarla karşılaşabilirsiniz ama iyi bir güvenlik ve performans için "off" duruma getirilir. Önerilen: CODE: 1. ------------------------- "allow_call_time_pass_reference" (Performans) Fonksiyonların çağrılma zamanında yaşanan uyumsuzluklarla ilgili uyarı verir. Önerilen: CODE: 1. ------------------------- "enable_dl" (Güvenlik) Bu değerin "off" kapalı olması gerekir aksi halde kişilerin sistemde php modüllerinde çalışma yapmasına olanak sağlar ve sistemde rahat dolaşmalarını sağlar güvenlik için kapalı olması gerekir. Önerilen: CODE: 1. ------------------------- "track_errors" (Güvenlik ve Performans) Sürücülerde meydana gelen hatalarda yetki verildiği taktirde hata mesajı errormsg olarak değişkende gösterilir. Önerilen: CODE: 1. ------------------------- "file_uploads" (Güvenlik) Açık olursa eğer sunucuda dosya yüklenmesine izin verilmiş olur ve bu da ciddi bir güvenlik açığına neden olur eğer kullandığınız scriptden herhangi bir dosya yüklemeniz gerekmiyorsa mutlaka kapalı duruma getiriniz. Bu sayede sitenize herhangi bir shell, script inject edise bile kesinlikle dosya yüklenmesine izin vermez. Önerilen: CODE: 1. ------------------------- "ignore_repeated_errors" (Güvenlik ve Performans) Açık olursa tekrarlanan hataları loglamaz. Önerilen: CODE: 1. ------------------------- "ignore_repeated_source" (Güvenlik ve Performans) Tekrarlanan mesajlar engellendiğinde, mesaj kaynağını engeller Bu ayar açık yapıldığında hataları loglamayacaktır farklı dosyalardan ya da kaynaklardan tekrarlanan mesajlarla. Önerilen: CODE: 1. ------------------------- "display_startup_errors" (Güvenlik ve Performans) "display_errors" değeri "on" açık olsa bile, Php'nin çalışma sırasında meydana gelen hatalar gözükmeyecektir. Bu değerin şiddetle "off" kapalı duruma getirilmesi önerilir. Önerilen: CODE: 1. ------------------------- "safe_mode_gid" (Güvenlik) UID - GID kontrollerini sadece UID ile yapmasına izin verir böylece aynı grupta dosyalar bulunsa bile göremezler yani serverda bulunan diğer clientların scriptlerini v.s görmeleri engellenir. Önerilen: CODE: 1. ------------------------- "output_buffering = 4096" (Performans) 4 KB'lik bir tampon çıktısı ayarlar "output buffer" Önerilen: CODE: 1. ------------------------- "register_argc_argv" (Performans) Kapalı olursa gereksiz ARGV ve ARGC kayıtlarını önler. PHP nin ARGV ve ARGC değişkenlerini bildirip bildirmemesini anlatır. Önerilen: CODE: 1. ------------------------- "php_value session.use_trans_sid - php_value session.use_only_cookies" Bu şekilde ayarlanması URL'deki PHPSESSID bilgilerini kaldırır. Önerilen: CODE: 1. ------------------------- "session.auto_start" Oturum başlatmayı başlangıçta isteme Önerilen: CODE: 1. ------------------------- "session.cookie_lifetime" Cookie'nin zaman ayarı Önerilen: CODE: 1. ------------------------- "memory_limit" Scriptin tükettiği maksimum hafıza miktarı Önerilen: CODE: 1. ------------------------- "post_max_size" PHP'nin kabul edeceği maksimum POST data boyutu Önerilen: CODE: 1. ------------------------- "upload_max_filesize" Upload edilen dosyaların maksimum boyutu Önerilen: CODE: 1. ------------------------- "upload_tmp_dir" Temporary klasörü HTTP'den gelen dosyalar, ayarlanmazsa default klasörü kullanacaktır. Önerilen: CODE: 1. ------------------------- "variables_order" (Ortam, GET, POST, Çerez, Sunucu) bunların işlenmedeki sıralarını belirler. Önerilen: CODE: 1. Üstte belirttiğim kodları "php.ini" dosyanıza alt alta ekleyebilirsiniz. ÖNEMLİ NOT: Bazen sadece safe mod'un açık olması bile bazı scriptlerinizin çalışmasını engeller. Üstte anlattıklarım en başta da belirttiğim gibi sizdeki güvenliği fazlasıyla arttırdığı için belki birçok web uygulamanız çalışmayacak hale gelecek fakat bazı web uygulamaları üstteki ayarlarla sorunsuz bir şekilde çalışabiliyor sadece script kurulumlarında fonksiyonları devre dışı bırakmanız gerekebilir. Bu yüzden bu ayarları sizin için en uygun olacak şekilde ayarlamalısınız gerekirse tek tek denemelisiniz. Kaynak: eno7 | eno7.org __________________________ (4 votes)
|
Benzer yazılarEtiketlerEn son forum mesajlarıYaklaşan Aktiviteler |
Re: "php.ini" Yapılandırmasıyla, Sitelerinizi Hacklenmelere Karş
teşekkürler çok güzel bir döküman olmuş, bir forumda yöneticilik yapiyorum izninle bu dökümanini senin adina yayinliyorum, teşekkür ederim...
teşekkür
paylaşımda bulunan bütün arkadaşlara teşekkür ederim üye oldum güzel birsite ve yardım isteyen arkadaşlar burası hack sıtesı dıye birşey yazıyormu ayreten mehtap denen arkadaş
lamer anlamını öğren yanlış kapıdasın .
eno7 yıde arada bir bakıyorum güzel bilgiler var onada teşekkür.
s.a
sitenın lınkını ve konu almamda sakınca olmaz sanırım kaynak belırtmek şartıyla.soralımda önceden
a.s.
Bu sitede dokümanı olan herkes bunu başkalarıyla paylaşmak için yapmıştır. Eğer başkaları onun yazdığı dokümanları kendisi yazmış gibi sitelerinde yayınlarlarsa yeni bir doküman paylaşmayı düşünmeyecektir. Buda bu konuda zaten az olan bilgili insanların daha az paylaşım yapması demek ve bu da hiç iyi değil.
eno7 de heralde dokümanın yazarı olarak belirtildiği sürece başka sitelerde yayınlanıp paylaşılmasına karşı çıkmayacaktır.
izin istediğiniz için teşekkürler. emeğe saygı duyanlar sayesinde paylaşımlar artacaktır.
kolay gelsin
Re: "php.ini" Yapılandırmasıyla, Sitelerinizi Hacklenmelere Karş
arkadasım burada biz hack ögretmiyoruz biz burada guvenlik hakkında bilgi veriyoruz ve yapmanız gerekeni soyluyoruz. sakın bunu hack olarak algılamayın hangi baslıkta su postu gordunuz. Falan Site Olympos.org tarafından hacklenmiştir. diye hiç birinde eminimki gormeyeceksinizde. bunları yaparsanız bunlar olur diye burada acıklama yapıyoruz. biz okey kolay gelsin ... !!!
__________________________www.hatavar.com Yakında !!!
yardım
mrb arkadslar. her onune gelen buraya uyemı oluyo demeyın sakın. bende hack ıng hakkında bısıler ogrenmek ıstıyorum. ne nedır nasıl yapılır. belkı yeterı kadar temelım yok ama subattan sonra ozellıkle yeterı kadar zamanım olacak. bu bana gerek normal yasamımda gerekse meslek hayatımda cok yardımcı olacak. yardım edebılırsenız, bana kaynak gosterıcek bı arkadas olursa sevınırım.
__________________________muhsby@hotmail.com tesekkurler
muhendis
Ankara
Türkiyem
AdR
Ben SaNa Bi DaHa OYuNa GeTiRiLMeMeK İÇiN Bi AdReS VeRiYiM ORaYa Bi GöZ GeZDiR. YaRDıMCı OLaCaĞıNı DüŞüNüYoRuM..
http://amasyalisesi.k12.tr/modules.php?name=Forums&file=viewtopic&t=200
ben msn kırmak istiyorum
beni çok fena oyuna getirdiler yalvarırım bana msn kırmayı öğretirmisin konuları çojk güzel anlatıyosun incitanem_emin@hotmail.com