Official course description:
This is an introductory course on information security. The course focuses on introductory aspects of analysis, design and implementation of secure software.
Security is a fundamental aspect that is necessary to take care of in today's development of software.
The student taking this course will have an introductory knowledge on attacker models, cryptographic tools and principal security protocol from real-world scenarios.
The course addresses four major topics:
- The principal security requirements and attacker models
- The fundamental cryptographic tools in Information Security
- Primary security protocols and Internet standards (PKI, TLS)
- Practical techniques for penetrating and hardening IT-systems
Before taking this course you must: 1. be familiar with C and Operating Systems 2. be familiar with computer networks 3. be superficially familiar with scripting languages 4. be familiar with the SQL query language 5. know basic algorithms and data structures 6. have implemented at least two medium-size programming projects (7.5 ECTS each) 7. be able to design, implement, and test medium-sized programs in Java or C# or other mainstream languages. 8. be familiar with basic discrete mathematics BSWU graduates fulfil these requirements. Otherwise, individual requirements can be satisfied by taking the BSWU courses: (1) Operating Systems and C, (2) Mobile and Distributed systems, (4) Introduction to Database Design, (5) Algorithms and Data Structures, (6,7) Analysis, Design and Software Architecture, (8) Foundations of Computing - Discrete Mathematics. The student must always meet the admission requirements of the IT University.
Intended learning outcomes
After the course, the student should be able to:
- Describe, relate, and discuss basic security principles
- Identify and describe access control techniques
- Identify, describe, and evaluate design approaches meeting specific security requirements
- Illustrate, analyse, and evaluate security standards
- Identify and describe the proper use of cryptography in security
- Describe and compare most common attack practices
- Describe and explain intrusion detection and prevention
- Analyse an IT-system for security risks and reflect on potential improvements of the system
Teaching consists of lectures and exercises. Coursework takes the following forms:
- Experimental lab work
- Project work
In project weeks, you are expected to be work independently; there are no lectures or exercise classes. Both teachers and tas will be available for questions in the period via various media, notably on learnit forums and in person at office hours.
The course concludes with project work as follows. Based on a set of functional requirements, you will design and implement a prototypical IT system. You will conduct a security analysis and devise appropriate security measures for this system. You will then swap systems with another group, and carry out a security review of this other group's system.
To be eligible for the examination, you must:
- You must submit and have approved 2 mandatory exercise sets.
- You must submit and have approved 2 mini-projects.
- You must be present and participate actively in the course conclusion workshop.
The purpose of the first mandatory activity is to understand the use of basic cryptographic primitives in security protocols, as well as observe the need for proper parameters when implementing these primitives.
The purpose of the second mandatory activity is to practice the design of security protocols based on advanced cryptographic primitives and secure channel protocols while practicing the analysis of security protocols according to security principles and the properties of underlying cryptographic primitives.
The purpose of the two mini-projects is to practice penetration testing techniques and to get familiarized with real-world security flaws in IT systems. The first mini-project aims at creating a hardened server hosting common IT services and the second mini-project aims at identifying and exploring security flaws in the servers created in the first mini-project. The course conclusion workshop aims at sharing the experience of the mini-projects among peers.All deadlines will be announced on the course page on LearnIT. Note that peer grade assignments are not considered approved unless you have both submitted yourself, as well as submitted feedback for at least two other assignments. If a mandatory activity is missed or not approved, you will receive a second attempt that must be submitted within two weeks of the activity's grade becoming available.
The student will receive the grade NA (not approved) at the ordinary exam, if the mandatory activities are not approved and the student will use an exam attempt.
Author/Editor: William Stallings & Lawrie Brown
Title: Computer Security: Principles and Practice, Global Edition
Author/Editor: Basin, David, Schaller, Patrick, Schläpfer,
Title: Applied Information Security: A Hands-on Approach
Student Activity BudgetEstimated distribution of learning activities for the typical student
- Preparation for lectures and exercises: 10%
- Lectures: 25%
- Exercises: 25%
- Assignments: 15%
- Project work, supervision included: 15%
- Exam with preparation: 10%
Ordinary examExam type:
A: Written exam on premises, External (7-point scale)
A22: Written exam on premises with restrictions.
Restricted access - LearnIT only
Written and printed books and notes
E-books and/or other electronic devices
B: Oral exam, External (7-point scale)
B22: Oral exam with no time for preparation.
Time and dateOrdinary Exam - on premises Thu, 21 Dec 2023, 09:00 - 13:00
Reexam Thu, 14 Mar 2024, 09:00 - 20:00
Reexam Fri, 15 Mar 2024, 09:00 - 17:00