Instructor: Tadayoshi (Yoshi) Kohno - yoshi@cs
Teaching Assistants:
Email everyone (preferred method to reach staff): cse484-tas@cs.washington.edu
In previous quarters we've used "Foundations of Security:
What Every Programmer Needs to Know", Daswani, Kern, and
Kesavan, ISBN 1-59059-784-2. Although it is still a good source
for learning many key aspects of security, it was published a long time ago.
It is not a required text.
In this course, we will cover topics including: the "security mindset", threat modeling, software security, cryptography, malware, web security, web privacy, smartphone security, authentication, usable security, anonymity, physical security, and security for emerging technologies.
For more details, see the course schedule.
CSE 332 and CSE 351
You should have maturity in both the mathematics of computer science and in the engineering of computer systems. This means that you should: have a good understanding of data structures and algorithms; be comfortable writing programs from scratch in C and Java; be comfortable writing and debugging assembly code; and be comfortable in a command-line Unix development environment (gdb, gcc, etc). You should also have a good understanding of computer architecture, operating systems, and computer networks. Most importantly, you should be eager to challenge yourself and learn more!