Foruma hoş geldin 👋, Ziyaretçi

Forum içeriğine ve tüm hizmetlerimize erişim sağlamak için foruma kayıt olmalı ya da giriş yapmalısınız. Foruma üye olmak tamamen ücretsizdir.

Kodunuzu Daha Güvenli Hale Getirmenin 5 Temel Adımı 🔐

nexter

Üye
Katılım
14 Mart 2026
Mesajlar
9
Kodunuzu Daha Güvenli Hale Getirmenin 5 Temel Adımı 🔐

Selam dostlar! Bugün biraz farklı bir konuya değinmek istiyorum. Hepimiz kod yazarken "çalışsın da nasıl çalışırsa çalışsın" moduna girebiliyoruz, değil mi? Ancak işler büyüdükçe, başkaları kodu okuduğunda veya bir güvenlik açığı ortaya çıktığında, "keşke daha temiz ve güvenli yazsaydım" dediğimiz anlar oluyor. Özellikle güvenlik, sonradan eklenmesi en zor özelliklerden biri. O yüzden gelin, işin başından itibaren kodumuzu nasıl daha güvenli bir temel üzerine inşa edebileceğimizin 5 pratik yoluna bakalım. 🛡️

1. Girdi Doğrulama: Dış Dünyaya Asla Güvenme!

Kodunuzun dışarıdan aldığı her şey - kullanıcıdan gelen veri, bir dosya, bir API'den gelen cevap - potansiyel bir tehdittir. İlk ve en kritik savunma hattınız, bu girdileri kullanmadan önce titizlikle doğrulamaktır.
  • Beyaz Liste Yaklaşımı: İzin verilen değerleri tanımlayın, gerisini reddedin. "Sadece şu karakterlere izin var" demek, "şu karakterlere izin yok" demekten her zaman daha güvenlidir.
  • Tür ve Aralık Kontrolü: Bir sayı bekliyorsanız, gelen verinin gerçekten sayı olduğundan ve mantıklı bir aralıkta olduğundan emin olun. Yaş alanına "999" yazılması pek mümkün değil, değil mi?
  • SQL Injection & XSS: Web dünyası için özellikle kritik. Kullanıcı girdisini olduğu gibi SQL sorgunuza veya HTML çıktınıza eklemeyin. Her dilin bunun için hazır parametreli sorgular veya çıkış kodlama (output encoding) fonksiyonları vardır, mutlaka kullanın.

2. En Az Ayrıcalık İlkesini Benimseyin

Bu prensip, bir kullanıcının, prosesin veya kod modülünün, işini yapabilmek için gereken minimum yetkiye sahip olması gerektiğini söyler. Neden mi?
  • Veritabanı bağlantınız sadece okuma yapacaksa, ona "root" yetkisi vermeyin. Sadece ilgili tablolarda SELECT yetkisi verin.
  • Uygulamanızın çalıştığı kullanıcı hesabı, sistemde süper yönetici olmak zorunda değil.
  • Bir fonksiyon, global bir değişkeni değiştirmeye ihtiyaç duymuyorsa, ona erişim izni vermeyin.
Böylece, eğer bir şey ters giderse (bir saldırı başarılı olursa), zararın yayılma alanı bu minimum yetki alanıyla sınırlı kalır.

3. Hassas Verileri Asla Düz Metin Olarak Saklamayın ve Loglamayın

Şifreler, API anahtarları, kredi kartı numaraları, kişisel iletişim bilgileri... Bu tür verilerle çalışırken ekstra hassas olmalıyız.
  • Şifreler için Hashleme: Kullanıcı şifrelerini asla, ama asla düz metin olarak veritabanına kaydetmeyin. Bunun yerine bcrypt, Argon2 gibi güçlü ve yavaş hash algoritmaları kullanın. Hash, şifreyi geri döndürülemez bir forma sokar.
    Python:
    # Python'da basit bir örnek (bcrypt kütüphanesi ile)
    import bcrypt
    
    # Şifreyi hash'le
    password = b"superGuvenliSifre123"
    hashed = bcrypt.hashpw(password, bcrypt.gensalt())
    # `hashed` değerini veritabanına kaydet.
    
    # Doğrulama yaparken
    input_password = b"kullaniciGirdisi"
    if bcrypt.checkpw(input_password, hashed):
        print("Şifre doğru!")
  • Loglara Dikkat: Hata ayıklama (debug) loglarınızı production ortamında açık bırakmayın. Ve loglara asla hassas veri yazdırmayın. "Kullanıcı X, şifresi '123456' ile giriş yapmaya çalıştı" gibi bir log, bir saldırganın rüyasıdır.

4. Bağımlılıklarınızı Güncel Tutun (Dependency Management)

Modern yazılım geliştirme, neredeyse başkalarının yazdığı paketler (kütüphaneler) üzerine inşa ediliyor. Ancak bu paketlerde keşfedilen güvenlik açıkları (vulnerabilities), sizin uygulamanızı da doğrudan etkiler.
  • Düzenli Güncelleme: Projenizdeki kütüphaneleri düzenli olarak güncelleyin. `npm audit`, `pip-audit`, `dotnet list package --vulnerable` gibi araçlar, kullandığınız paketlerdeki bilinen güvenlik açıklarını taramanıza yardımcı olur.
  • Versiyon Sabitleme: `package.json` veya `requirements.txt` dosyanızda kütüphane versiyonlarını sabitleyin (`==2.4.1` gibi). Bu, farklı ortamlarda tutarlılık sağlar ve kontrolsüz bir major güncellemenin getireceği kırılmaları önler. Ancak, güvenlik güncellemelerini (patch versiyonlar) düzenli olarak uygulamayı unutmayın.

5. Hata Yönetimini Bilinçli Yapın (Error Handling)

Hatalar kaçınılmazdır. Ancak onları nasıl ele aldığınız, güvenlik ve kullanıcı deneyimi açısından çok önemlidir.
  • Ayrıntılı Hata Mesajlarını Kullanıcıya Göstermeyin: Bir hata oluştuğunda, kullanıcıya "Dosya 'C:\db\passwords.txt' bulunamadı, hatası: Access Denied" gibi bir mesaj vermek, sisteminiz hakkında saldırgana çok değerli bilgiler verir. Bunun yerine genel bir "Bir hata oluştu, lütfen daha sonra tekrar deneyin" mesajı gösterin. Ayrıntılı hata, sadece geliştiricilerin görebileceği loglarda kalmalı.
  • Tüm Olasılıkları Yakalayın: Dosya okuma/yazma, ağ bağlantısı, veritabanı sorguları gibi güvenilir olmayan (unreliable) işlemleri her zaman `try-catch` blokları içine alın. Kontrolsüz bir şekilde çöken bir uygulama, beklenmedik durumlara ve potansiyel güvenlik açıklarına yol açabilir.

Umarım bu adımlar, kodlarınızı yazarken aklınızın bir köşesinde durur ve projelerinizi daha sağlam temeller üzerine kurmanıza yardımcı olur. Unutmayın, güvenlik bir özellik değil, bir mindset'tir. 🧠

**Peki ya siz? Kod güvenliği konusunda en çok hangi adımı atlıyorsunuz veya hangi konuda zorlanıyorsunuz? Deneyimlerinizi yorumlarda paylaşın, birlikte öğrenelim!** 💬
 

Tema özelleştirme sistemi

Bu menüden forum temasının bazı alanlarını kendinize özel olarak düzenleye bilirsiniz.

Zevkine göre renk kombinasyonunu belirle

Tam ekran yada dar ekran

Temanızın gövde büyüklüğünü sevkiniz, ihtiyacınıza göre dar yada geniş olarak kulana bilirsiniz.

Geri