Ders Adı | Kodu | Yarıyıl | T+U Saat | Kredi | AKTS |
---|---|---|---|---|---|
Güvenli Yazılım Geliştirme | SWE 220 | 4 | 3 + 0 | 3 | 4 |
Ön Koşul Dersleri | |
Önerilen Seçmeli Dersler | |
Dersin Dili | Türkçe |
Dersin Seviyesi | Lisans |
Dersin Türü | Zorunlu |
Dersin Koordinatörü | Dr.Öğr.Üyesi DENİZ BALTA |
Dersi Verenler | Dr.Öğr.Üyesi DENİZ BALTA, |
Dersin Yardımcıları | |
Dersin Kategorisi | Diğer |
Dersin Amacı | Güvenli yazılım geliştirme ile ilgili temel kavramlarını öğrenmek, güvenli yazılım geliştirme süreç ve araçları hakkında bilgi sahibi olmak. |
Dersin İçeriği | Yazılım güvenliği ilkeleri, Yazılım güvenliğini sağlama yöntemleri, Güvenli yazılım geliştirme yaşam döngüsü, Güvenlik test araçları, Güvenli yazılım geliştirme yaşam döngüsü süreçleri ve olgunluk modelleri (Microsoft SDL, OWASP SAMM, BSIMM), Uygulama güvenliği ve kuralları, Güvenli yazılım geliştirme denetim listesi, Web Uygulamaların Güvenliği, Proje çalışmaları |
# | Ders Öğrenme Çıktıları | Öğretim Yöntemleri | Ölçme Yöntemleri |
---|---|---|---|
1 | Güvenli Yazılım Geliştirme Yaşam Döngüsünü Tanır | Anlatım, Soru-Cevap, | Kısa Cevaplı Testler, |
2 | Güvenli Uygulamaların Nasıl Oluşturulacağını Öğrenir | Anlatım, Soru-Cevap, | Kısa Cevaplı Testler, Eşleştirme Testler, |
3 | Uygulama Tabanlı Saldırıları Tanır | Anlatım, Soru-Cevap, | Kısa Cevaplı Testler, Eşleştirme Testler, |
Hafta | Ders Konuları | Ön Hazırlık |
---|---|---|
1 | Yazılımların Güvenliği temel kavramları | |
2 | Yazılım Güvenliği Prensipleri, Yazılım Güvenliğini Sağlama Yöntemleri | |
3 | Güvenli yazılım geliştirme yaşam döngüsü | |
4 | Güvenli Yazılım Geliştirme Olgunluk Modelleri, Web Uygulamalarının Temelleri ve Özellikleri | |
5 | Güvenli Yazılım Geliştirme Olgunluk Modelleri, Web Uygulamalarının Temelleri ve Özellikleri | |
6 | INJECTION ATTACK | |
7 | INJECTION ATTACK | |
8 | Ara Sınav | |
9 | Cross Site Scripting (XSS) | |
10 | Cross Site Request Forgery(CSRF) | |
11 | Server Side Request Forgery(SSRF) | |
12 | Cross Origin Resource Sharing (CORS) | |
13 | Proje Çalışması | |
14 | Proje Çalışması |
Kaynaklar | |
---|---|
Ders Notu | |
Ders Kaynakları | Software Security: Building Security In by Gary McGraw. Addison-Wesley TUBITAK Secure Software Development Guide DDO-Information and Communication Security Guide-3.2.6 Secure Software Development 24 Deadly Sins of Software Security, ISBN: 978-0-07-162675-0 , by Howard, LeBlanc, and Viega
|
Sıra | Program Çıktıları | Katkı Düzeyi | |||||
---|---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | |||
1 | Matematik, fen bilimleri ve ilgili mühendislik disiplinine özgü konularda yeterli bilgi birikimi; bu alanlardaki kuramsal ve uygulamalı bilgileri, karmaşık mühendislik problemlerinde kullanabilme becerisi. | ||||||
2 | Karmaşık mühendislik problemlerini saptama, tanımlama, formüle etme ve çözme becerisi; bu amaçla uygun analiz ve modelleme yöntemlerini seçme ve uygulama becerisi. | ||||||
3 | Mühendislik uygulamalarında karşılaşılan karmaşık problemlerin analizi ve çözümü için gerekli olan modern teknik ve araçları geliştirme, seçme ve kullanma becerisi; bilişim teknolojilerini etkin bir şekilde kullanma becerisi. | ||||||
4 | Karmaşık bir sistemi, süreci, cihazı veya ürünü gerçekçi kısıtlar ve koşullar altında, belirli gereksinimleri karşılayacak şekilde tasarlama becerisi; bu amaçla modern tasarım yöntemlerini uygulama becerisi. | ||||||
5 | Karmaşık mühendislik problemlerinin veya disipline özgü araştırma konularının incelenmesi için deney tasarlama, deney yapma, veri toplama, sonuçları analiz etme ve yorumlama becerisi. | ||||||
6 | Bilişim Teknolojilerinin yönetim, denetim, gelişim ve güvenliği/güvenilirliği hakkında bilgi sahibi olma ve farkındalık. | ||||||
7 | Disiplin içi ve çok disiplinli takımlarda etkin biçimde çalışabilme becerisi; bireysel çalışma becerisi. | ||||||
8 | Türkçe sözlü ve yazılı etkin iletişim kurma becerisi; en az bir yabancı dil bilgisi; etkin rapor yazma ve yazılı raporları anlama, tasarım ve üretim raporları hazırlayabilme, etkin sunum yapabilme, açık ve anlaşılır talimat verme ve alma becerisi. | ||||||
9 | Yaşam boyu öğrenmenin gerekliliği bilinci; bilgiye erişebilme, bilim ve teknolojideki gelişmeleri izleme ve kendini sürekli yenileme becerisi. | ||||||
10 | Etik ilkelerine uygun davranma, mesleki ve etik sorumluluk bilinci; mühendislik uygulamalarında kullanılan standartlar hakkında bilgi. | ||||||
11 | Proje yönetimi, risk yönetimi ve değişiklik yönetimi gibi, iş hayatındaki uygulamalar hakkında bilgi; girişimcilik, yenilikçilik hakkında farkındalık; sürdürülebilir kalkınma hakkında bilgi. | ||||||
12 | Mühendislik uygulamalarının evrensel ve toplumsal boyutlarda sağlık, çevre ve güvenlik üzerindeki etkileri ve çağın mühendislik alanına yansıyan sorunları hakkında bilgi; mühendislik çözümlerinin hukuksal sonuçları konusunda farkındalık. |
# | Ders Öğrenme Çıktılarının Program Çıktılarına Katkısı | PÇ 1 | PÇ 2 | PÇ 3 | PÇ 4 | PÇ 5 | PÇ 6 | PÇ 7 | PÇ 8 | PÇ 9 | PÇ 10 | PÇ 11 | PÇ 12 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | Güvenli Yazılım Geliştirme Yaşam Döngüsünü Tanır | 5 | 5 | 5 | |||||||||
2 | Güvenli Uygulamaların Nasıl Oluşturulacağını Öğrenir | 5 | |||||||||||
3 | Uygulama Tabanlı Saldırıları Tanır | 5 | 5 |
Değerlendirme Sistemi | |
---|---|
Yarıyıl Çalışmaları | Katkı Oranı |
1. Ara Sınav | 50 |
1. Kısa Sınav | 10 |
2. Kısa Sınav | 10 |
1. Proje / Tasarım | 30 |
Toplam | 100 |
1. Final | 40 |
1. Yıl İçinin Başarıya | 60 |
Toplam | 100 |
AKTS - İş Yükü Etkinlik | Sayı | Süre (Saat) | Toplam İş Yükü (Saat) |
---|