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.
Java programming experience is essential Servlets programming experience is required JSP page-authoring experience is recommended but not required Understanding of RESTful web services as implemented in JAX-RS will be highly beneficial, but is not strictly required.
5 Days/Lecture & Lab
This course is designed for experienced developers of Java EE applications.
- Secure Web Applications
- Authentication and Authorization
- Common Web Attacks
- Input Validation
- HTTPS and Certificates
- Application-Level Cryptography
- Secure Development Practices
- REST Security Basics
- HMAC Security
- SAML SSO
- Appendix A. Learning Resources