|
|
(9 intermediate revisions by 2 users not shown) |
Line 1: |
Line 1: |
− | ==Goals==
| + | The Java Project Roadmap has moved. You will find it now at [http://www.owasp.org/index.php/OWASP_Java_Project#tab=Roadmap OWASP Java Project Roadmap]. |
− | | |
− | The OWASP Java Project's overall goal is to... | |
− | | |
− | Produce materials that show J2EE architects, developers, and
| |
− | deployers how to deal with most common application security
| |
− | problems throughout the lifecycle.
| |
− | | |
− | In the near term, we are focused on the following tactical goals:
| |
− | | |
− | # Provide examples of how to prevent Cross Site Scripting attacks in popular web frameworks
| |
− | # Provide examples of how to prevent SQL Injection in popular data access frameworks
| |
− | # Provide examples of how to prevent LDAP injection in Java
| |
− | # A practical guide to implementing a security policy for a Java web application
| |
− | # Secure configuration guides for popular application servers
| |
− | | |
− | ==Current Tasks==
| |
− | * Call for volunteers - Join the [http://lists.owasp.org/mailman/listinfo/java-project mailing list], read the [[Tutorial]] and get started!
| |
− | * Refine this roadmap in the [http://www.owasp.org/index.php/Talk:OWASP_Java_Project_Roadmap discussion].
| |
− | | |
− | ==Ideas==
| |
− | | |
− | Please submit your ideas for the OWASP Java Project here (you can sign your ideas by adding four tilde characters like this <nowiki>~~~~</nowiki>)
| |
− | * It would be useful to have a library of J2EE security resources on the web. In addition to URLs, I think these should have short summaries that explain what the resource is about. I've clicked on far too many "J2EE Security" links only to find that the article is about implementing access control in Tomcat.
| |
− | * A tool that automatically generates a security policy for a given application could be useful. The tool is first run in learning mode where it maps all the accesses that the application attempts and then generates a policy based on those access attempts. Status: tool sent to Stephen.
| |
− | | |
− | ==[[J2EE Security for Architects]]==
| |
− | | |
− | ===Design considerations===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Discuss the security implications of common J2EE architectures. This could be discussed in terms of: Authentication, Authorisation, Data Validation, Cross Site Scripting protection. Other architecture concerns such as scalability, performance and maintainability can also be mentioned, but the focus on security should not be lost.
| |
− |
| |
− | Any other security concerns that should be addressed during the design phase should also be mentioned here.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * Architectural considerations
| |
− | ** EJB Middle tier
| |
− | ** Web Services Middle tier
| |
− | ** Spring Middle tier
| |
− | | |
− | ===Noteworthy Frameworks===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Discuss important and relevant Java security frameworks that would be useful to architects. The information should be at a suitably high level, for example, by discussing the advantages and features as well as the associated costs (direct and indirect) of using the frameworks.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Comparison of Frameworks in progress</td></tr>
| |
− | <tr><td valign="top"><b>Contributors: </b></td><td>Claire McDonough, Ranjita Shankar Iyer</td></tr>
| |
− | <tr><td><b>Reviewers: </b></td><td>Rohyt Belani, Stephen De Vries</td></tr>
| |
− | </table>
| |
− | 1. Struts
| |
− | 2. Turbine
| |
− | 3. JFS (MyFaces)
| |
− | 4. Tapestry
| |
− | 5. Webwork
| |
− | 6. Cocoon
| |
− | 7. Tiles
| |
− | 8. SiteMesh
| |
− | 9. Spring
| |
− | | |
− | ==[[J2EE Security for Developers]]==
| |
− | | |
− | ===Java Security Basics===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Provide an introduction into the basic security services provided by the Java language and environment. Remember to keep this relevant for web developers for the initial release - there may be a potential to expand this to thick clients in subsequent releases.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Outline development</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td>Shyaam Sundhar</td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td>Rohyt Belani, Stephen De Vries</td></tr>
| |
− | </table>
| |
− | * Class Loading
| |
− | * Bytecode verifier
| |
− | * The Security Manager and security.policy file
| |
− | | |
− | ===Input Validation===
| |
− | * Overview
| |
− | * Dangerous calls (BufferedReader.readLine(), ServletRequest.getParameter(), etc...)
| |
− | | |
− | ==== SQL Injection====
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Provide cursory background information on SQL injection and refer to the Guide for more indepth coverage (no need to duplicate info in the Guide). This section should provide practical advise and real-world code examples for developers. If you feel that a popular persistence framework is not covered, please add it!</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Work is underway</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td>[[User:Stephendv|Stephendv]], Joe Kumar</td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * Overview
| |
− | * Prevention
| |
− | ** White Listing
| |
− | ** Prepared Statements
| |
− | ** Stored Procedures
| |
− | ** Hibernate
| |
− | ** Ibatis
| |
− | ** Spring JDBC
| |
− | ** EJB 3.0
| |
− | ** JDO
| |
− | | |
− | ====Cross Site Scripting (XSS)====
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Provide cursory background information on XSS and refer to the Guide for more indepth coverage. This section should provide practical advise and real-world code examples for developers. If you would like to see coverage of a web framework that's not listed, please add it!</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * Overview
| |
− | * Prevention
| |
− | ** White Listing
| |
− | ** Manual HTML Encoding
| |
− | ** Preventing XSS in popular Web Frameworks
| |
− | *** JSP/JSTL
| |
− | *** Struts
| |
− | *** Spring MVC
| |
− | *** Java Server Faces
| |
− | *** WebWork
| |
− | *** Wicket
| |
− | *** Tapestry
| |
− | * CSRF attack
| |
− | | |
− | ==== LDAP Injection ====
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>As with the other Injection sections, only provide cursory information on the general case. Should contain practical real-world advise and code examples for preventing LDAP injection.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td>[[User:Stephendv|Stephendv]]</td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * Overview
| |
− | * Prevention
| |
− | | |
− | ==== XPATH Injection ====
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>As with the other Injection sections, only provide cursory information on the general case. Should contain practical real-world advise and code examples for preventing XPATH injection.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * Overview
| |
− | * Prevention
| |
− | | |
− | ==== Miscellaneous Injection Attacks ====
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Should contain practical real-world advise and code examples.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * HTTP Response splitting
| |
− | * Command injection - Runtime.getRuntime().exec()
| |
− | | |
− | === Authentication===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Discuss authentication for Java and J2EE apps under the suggested headings below. Examples for container managed authentication of specific application servers are also welcome.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td>Dave Ferguson, Michel Prunet, Adrian San Juan, Philippe Curmin</td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * Storing credentials - Adrian San Juan
| |
− | * [[Hashing Java|Hashing]] - Michel Prunet
| |
− | * [[SSL Best Practices]] - Philippe Curmin is working on it.
| |
− | * [[Using JCaptcha]]
| |
− | * Container-managed authentication with Realms
| |
− | ** [[Declarative Access Control in Java]]
| |
− | * JAAS Authentication
| |
− | * Password length & complexity - Adrian San Juan
| |
− | | |
− | ===Session Management===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>The generic problems and solutions for session management are covered in the Guide. This section should focus on Java specific examples. </td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * Logout
| |
− | * Session Timeout
| |
− | * Absolute Timeout
| |
− | * Session Fixation
| |
− | * Terminating sessions
| |
− | ** Terminating sessions when the browser window is closed
| |
− | | |
− | ===Authorization===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Java and J2EE specific discussion and examples.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * In presentation layer
| |
− | * In business logic
| |
− | * In data layer
| |
− | * Declarative v/s Programmatic
| |
− | * web.xml configuration - [[Declarative Access Control in Java]]
| |
− | * [[Forced browsing]]
| |
− | * JAAS
| |
− | * EJB Authorization
| |
− | * Acegi
| |
− | * JACC
| |
− | * Check horizontal privilege
| |
− | | |
− | === Encryption===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Java and J2EE specific discussion and examples.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * JCE
| |
− | * Storing db secrets
| |
− | * Encrypting JDBC connections
| |
− | * JSSE
| |
− | * Random number generation
| |
− | | |
− | === Error Handling & Logging===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Java and J2EE specific discussion and examples.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * Output Validation
| |
− | * Custom Errors
| |
− | * Logging - why log? what to log? log4j, etc.
| |
− | * Exception handling techniques
| |
− | ** fail-open/fail-closed
| |
− | ** resource cleanup
| |
− | ** finally block
| |
− | ** swallowing exceptions
| |
− | * Exception handling frameworks
| |
− | ** Servlet spec - web.xml
| |
− | ** JSP errorPage
| |
− | * Web application forensics
| |
− | | |
− | === Web Services Security ===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Discuss securely implementing Web Services using Java technologies. Examples using specific frameworks are welcome. The topic list is a bit light at the moment, please add more topics if they're relevant.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * SAML
| |
− | * (X)WS-Security
| |
− | * SunJWSDP
| |
− | * XML Signature (JSR 105)
| |
− | * XML Encryption (JSR 106)
| |
− | | |
− | === Code Analysis Tools ===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>The introduction should cover the advantages and short comings of code analysis tools. An overview of the current state of the art and the available tools would go well here. As a start, only open source tools are listed, but if vendors of commercial tools adhere to the [[Tutorial]] guidelines, these submissions will be gladly received.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * Introduction
| |
− | * FindBugs
| |
− | ** Creating custom rules
| |
− | * PMD
| |
− | ** Creating custom rules
| |
− | * JLint
| |
− | * Jmetrics
| |
− | | |
− | == [[J2EE Security For Deployers]] ==
| |
− | | |
− | === Securing Popular J2EE Servers ===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Practical step-by-step guides to securing various J2EE servers. Examples of secure configurations can also be provided for download. If configurations are provided, they should be properly commented so that the rationale for configuration settings is clearly explained. Users of the configurations should be provided with enough information to make their own risk decisions.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td>Darren Edmonds</td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * [https://www.owasp.org/index.php/securing_tomcat Securing Tomcat] - Darren Edmonds
| |
− | * Securing JBoss
| |
− | * Securing WebLogic
| |
− | * Securing WebSphere
| |
− | * Others...
| |
− | | |
− | === Defining a Java Security Policy === | |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Practical information on creating a Java security policies for J2EE servers.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Call for volunteers</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td></td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td></td></tr>
| |
− | </table>
| |
− | * PolicyTool
| |
− | * jChains (www.jchains.org)
| |
− | | |
− | === Protecting Binaries ===
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>This should be focussed on web applications, so examples should include applets and web start apps.</td></tr>
| |
− | <tr><td valign="top"><b>Status:</b></td><td>Outline development</td></tr>
| |
− | <tr><td valign="top"><b>Contributors:</b></td><td>Richard Seiersen</td></tr>
| |
− | <tr><td><b>Reviewers:</b></td><td>Rohyt Belani</td></tr>
| |
− | </table>
| |
− | * Bytecode manipulation tools and techniques
| |
− | * Bytecode obfuscation (proguard)
| |
− | * Convert bytecode to native machine code
| |
− | * Signing jar files with jarsigner
| |
− | | |
− | ==[[J2EE Security for Security Analysts and Testers]]==
| |
− | | |
− | This is a proposed section that seems to be a good place to put articles that don't fit into some of the other categories. [[User:Jeff Williams|Jeff Williams]] 17:41, 30 June 2006 (EDT)
| |
− | | |
− | * Using Eclipse to verify Java applications
| |
− | * Using Findbugs, PMD, Metrics, NCSS, jLint to find flaws and bugs
| |
− | * Using [[:Category:OWASP WebScarab Project|WebScarab]] to find vulnerabilities in J2EE applications - is there anything that would be specific to J2EE apps here? Wouldn't using webscarab apply to all web apps? [[User:Stephendv|Stephendv]] 07:14, 17 July 2006 (EDT)
| |
− | * Decompiling Java bytecode
| |
− | | |
− | == [[Java Resources]] ==
| |
− | <table border=1 cellpadding=5>
| |
− | <tr><td valign="top"><b>Objective:</b></td><td>Define other Java security resources, links, papers and books that would be useful to the community.</td></tr>
| |
− | </table>
| |
− | | |
− | [[Category:OWASP Java Project]]
| |