Software Engineering Institute | Carnegie Mellon University
Software Engineering Institute | Carnegie Mellon University

Secure Coding in Java

Producing secure programs requires secure designs. However, even the best designs can lead to insecure programs if developers are unaware of the many security pitfalls inherent in Java programming. This four-day course provides a detailed explanation of common programming errors in Java and describes how these errors can lead to code that is vulnerable to exploitation. The course concentrates on security issues intrinsic to the Java programming languages and associated libraries. The intent is for this course to be useful to anyone involved in developing secure Java programs regardless of the specific application.

Please note: you must bring a laptop computer equipped with the latest version of Adobe Reader and VMware Player. See the Prerequisites section for download information.

The course assumes basic Java programming skills but does not assume an in-depth knowledge of software security. Material in this presentation was derived from the Addison-Wesley books The CERT Oracle Secure Coding Standard for Java and Java Coding Guidelines.

To learn more about the CERT Secure Coding eLearning and Professional Certificates, please go to: www.cert.org/go/secure-coding

Who should attend?

This course is designed for Java developers.


Topics

  • Input Sanitization and Validation
  • Objects and Methods
  • Exceptions
  • File I/O
  • The Java Memory Model
  • Concurrency
  • The Java Security Model
  • Historical Vulnerabilities and Exploits

Subjects covered in the first two days are general. As in Java, the material is designed to be platform-independent. However, some platform-specific information is provided when necessary. For example, files have subtly different properties on Windows vs. POSIX. The final day focuses on Java's security architecture, that allows untrusted code to coexist with trusted code, and concludes with several historical examples of famous exploits.

Objectives

Participants should come away from this course with a working knowledge of common programming errors that lead to software vulnerabilities, how these errors can be exploited, and effective mitigation strategies for preventing the introduction of these errors. In particular, participants will learn how to

  • improve the overall security of any Java application
  • avoid injection attacks, such as SQL injection and XSS
  • understand Java's memory model, with a thorough grounding of concurrency, and learn how to prevent race conditions while avoiding deadlock
  • learn when to throw and catch exceptions
  • avoid I/O vulnerabilities, including file-based race conditions
  • learn how historical exploits on Java were executed and later disabled

Moreover, this course encourages programmers to adopt security best practices and develop a security mindset that can help protect software from tomorrow's attacks, not just today's.

Prerequisites

It is recommended that participants have a basic to intermediate understanding of the Java programming language. Software security knowledge or experience is not required.

Required Equipment

Students must bring a personal computer equipped with

On the first day of the course, the instructor will provide the attendees with a DVD with the software and course exercises to download on their computers. The instructor will also provide instructions on using the Rosebud Virtual Machine (VM) from the DVDs.

Materials

The CERT Oracle Secure Coding Standard for Java and Java Coding Guidelines books authored by Long, Mohindra, Seacord, Sutherland, and Svoboda and published by Addison-Wesley will be provided. Participants will also receive a DVD containing course and reference materials.

Schedule

This four-day class meets at the following times:

Days 1-4, 9:00 a.m. - 5:00 p.m. (U.S. Locations)
Days 1-4, 9:30 a.m. - 5:30 p.m. (non-U.S. Locations)


Training courses provided by the SEI are not academic courses for academic credit toward a degree. Any certificates provided are evidence of the completion of the courses and are not official academic credentials.

Course Details

 
This course may be offered by special arrangement at customer sites.

For More Information

E-mail: course-info@sei.cmu.edu
Phone: 412-268-7622