Bozukluk kontrolü - Taint checking - Wikipedia

Bozukluk kontrolü bazılarında bir özelliktir bilgisayar Programlama Diller, gibi Perl[1] ve Yakut,[2] Kötü niyetli kullanıcıların bir ana bilgisayarda komutları çalıştırmasını önleyerek güvenliği artırmak için tasarlanmıştır. Bozukluk kontrolleri, öncelikle aşağıdaki gibi teknikler kullanılarak saldırıya uğrayan web siteleriyle ilişkili belirli güvenlik risklerini vurgular: SQL enjeksiyonu veya arabellek taşması saldırısı yaklaşımlar.

Genel Bakış

Bozukluk kontrolünün arkasındaki kavram, bir dış kullanıcı tarafından değiştirilebilen herhangi bir değişkenin (örneğin, bir alandaki bir alan tarafından ayarlanan bir değişken) internet formu ) potansiyel bir güvenlik riski oluşturur. Eğer değişken ikinci bir değişkeni belirleyen bir ifadede kullanılır, bu ikinci değişken de artık şüphelidir. Bozulma kontrol aracı daha sonra değişkenle devam ederek, potansiyel olarak dış girdiden etkilenen değişkenlerin bir listesini oluşturabilir. Bu değişkenlerden herhangi biri tehlikeli komutları yürütmek için kullanılırsa (bir SQL veritabanına veya ana bilgisayara doğrudan komutlar gibi) işletim sistemi ), kusur denetleyicisi, programın potansiyel olarak tehlikeli bir bozuk değişken kullandığını bildirir. Bilgisayar programcısı daha sonra tehlikeli girdinin etrafına güvenli bir duvar dikmek için programı yeniden tasarlayabilir.

Bozukluk kontrolü, tam doğrulamanın ihtiyatlı bir tahmini olarak görülebilir. karışmama veya daha genel bir kavram güvenli bilgi akışı.[3] Bir sistemdeki bilgi akışı, o sistemin tek bir yürütme izi incelenerek doğrulanamadığından,[4] Bozukluk analizinin sonuçları, uygulandığı sistemin bilgi akışı özelliklerine ilişkin yaklaşık bilgileri zorunlu olarak yansıtacaktır.[5]

Misal

Aşağıdaki tehlikeli Perl kod büyük bir SQL enjeksiyonu güvenlik açığının değerini kontrol etmemek $ isim değişken:

#! / usr / bin / perlbenim $ isim = $ cgi->param("isim");  # Tarayıcıdan adı alın...$ dbh->{TaintIn} = 1;$ dbh->yürütmek("SEÇİN * kullanıcılardan WHERE name = '$ isim';"); # Bir SQL sorgusu yürütün

Bozukluk kontrolü açıksa, Perl komutu çalıştırmayı reddeder ve bir SQL sorgusunda bozuk bir değişken kullanıldığından bir hata mesajıyla çıkılır. Bozulma kontrolü olmadan bir kullanıcı girebilir foo '; DROP TABLE kullanıcıları -, böylece tüm veritabanı tablosunu silen bir komut çalıştırır. $ Name'in bozuk değerini bir SQL olarak kodlamak çok daha güvenli olacaktır. dize değişmezi ve sonucu SQL sorgusunda kullanın, hiçbir tehlikeli komutun gömülü olmadığını garanti eder. $ isim değerlendirilecektir. Bunu başarmanın başka bir yolu da hazırlanan açıklama bir sorgu için tüm değişken girdileri temizlemek için.

Unutulmaması gereken bir şey şudur: Perl DBI ayarlamak için bir tane gerektirir TaintIn bir veritabanı tutamacının özniteliği Hem de sorun modunun kişinin SQL dizelerini kontrol etmesini sağlamak.[6]

Tarih

Perl destekli lekelenme setuid betikleri en az sürüm 3.0'dan (1989'da piyasaya sürüldü)[7]ancak 5.0 sürümüne kadar değildi (1994'te piyasaya sürüldü)[7] bu -T değiştirmek[1] lekelemeyi tek bir çalışma zamanına entegre ederek tanıtıldı.

1996 yılında Netscape uygulanan veri lekesi sunucu tarafı JavaScript içinde Netscape Communications Server,[kaynak belirtilmeli ] Hem de müşteri tarafı Netscape Navigator için 3.[8]Ancak, istemci tarafı desteği deneysel olarak kabul edildiğinden devre dışı bırakıldı (etkinleştirmek için kullanıcı müdahalesi gerektirdi) ve sayfa yazarlarının bundan yararlanmak için komut dosyalarını değiştirmesi gerekiyordu. Diğer tarayıcı satıcıları bu işlevi hiçbir zaman uygulamadılar; ne de Communications Server'ın birincil rakibi, Microsoft'un (o zaman) yeni İnternet Bilgi Sunucusu.

Referanslar

  1. ^ a b "perlsec - Perl güvenliği". Perl 5 geliştirme ekibi. Alındı 2012-05-20.
  2. ^ Ruby Programlama - Pragmatik Programcı Kılavuzu. Addison Wesley Longman. 2001. s. 253 (Böl. 20).
  3. ^ A. Sabelfeld ve A. C. Myers, "Dile dayalı bilgi akışı güvenliği", İletişimde Seçilmiş Alanlar Üzerine IEEE Dergisi, 2003.
  4. ^ J. Ligatti, L. Bauer, D. Walker. "Otomatik verileri düzenle: Çalışma zamanı güvenlik politikaları için uygulama mekanizmaları". Uluslararası Bilgi Güvenliği Dergisi, 2005
  5. ^ T. Terauchi ve A. Aiken. "Bir güvenlik sorunu olarak güvenli bilgi akışı". İçinde 12. Uluslararası Statik Analiz Sempozyumu, Eylül 2005.
  6. ^ "DBI - Perl için veritabanından bağımsız arayüz". Alındı 2020-08-29.
  7. ^ a b "perlhist - Perl geçmiş kayıtları". Perl 5 geliştirme ekibi. Alındı 2020-08-29.
  8. ^ Flanagan, David (1997). JavaScript: Kesin Kılavuz (2. baskı). O'Reilly & Associates. s. 321. ISBN  9781565922341. [...] veri lekeleme güvenlik modeli Navigator 3.0'da deneyseldir ve varsayılan olarak etkinleştirilmemiştir. Bununla birlikte, Navigator'ın 4.0 sürümünde varsayılan güvenlik modeli olması bekleniyor.

Dış bağlantılar