JVA-122: Secure Java Web Development

Course Description

This comprehensive course shows experienced developers of Java EE applications how to secure those applications and to apply best practices with regard to secure enterprise coding. Authentication, authorization, and input validation are major themes, and students get good exposure to basic Java cryptography for specific development scenarios, as well as thorough discussions of HTTPS configuration and certificate management, error handling, logging, and auditing.
Perhaps the most eye-opening parts of the course concern common web “hacks,” or attack vectors. Students see how easy it is to leave an application unguarded against cross-site scripting (XSS), cross-site request forgery (CSRF), SQL injection, and other attack types — and learn that it’s also easy to fix such vulnerabilities and the importance of a secure development process.
In the last part of the course we move beyond the scope of traditional, interactive web applications to consider RESTful web services, single sign-on systems, and third-party authorization. Students learn to perform HMAC cryptography as a means of HTTP message-level authentication, and get introductions and hands-on exercise with SAML SSO and OAuth.

Course Length: 5 days

Prerequisites: 

  • Java programming experience is essential — Course 103 is excellent preparation.
  • Servlets programming experience is required — Course 111
  • JSP page-authoring experience is recommended but not required — again, Course 111.
  • Understanding of RESTful web services as implemented in JAX-RS will be highly beneficial, but is not strictly required. Consider Course 563.

Detailed Course Outline (PDF)

KTP logo Kubernetes Logo OpenStack Logo Red Hat logo