This site is the archived OWASP Foundation Wiki and is no longer accepting Account Requests.
To view the new OWASP Foundation website, please visit https://owasp.org
Difference between revisions of "Category:OWASP Enterprise Security API"
From OWASP
KateHartmann (talk | contribs) |
m (Update Javadoc link on main tab to reference 2.2.0.0 release.) |
||
(45 intermediate revisions by 14 users not shown) | |||
Line 1: | Line 1: | ||
− | ==== | + | = Home = |
+ | <div style="width:100%;height:160px;border:0,margin:0;overflow: hidden;">[[File:OWASP_Project_Header.jpg|link=]]</div> | ||
+ | |||
+ | {| style="padding: 0;margin:0;margin-top:10px;text-align:left;" |- | ||
+ | | valign="top" style="border-right: 1px dotted gray;padding-right:25px;" | | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
ESAPI (The OWASP Enterprise Security API) is a free, open source, web application security control library that makes it easier for programmers to write lower-risk applications. The ESAPI libraries are designed to make it easier for programmers to retrofit security into existing applications. The ESAPI libraries also serve as a solid foundation for new development. | ESAPI (The OWASP Enterprise Security API) is a free, open source, web application security control library that makes it easier for programmers to write lower-risk applications. The ESAPI libraries are designed to make it easier for programmers to retrofit security into existing applications. The ESAPI libraries also serve as a solid foundation for new development. | ||
Line 19: | Line 17: | ||
This project source code is licensed under the [http://en.wikipedia.org/wiki/BSD_license BSD license], which is very permissive and about as close to public domain as is possible. The project documentation is licensed under the [http://creativecommons.org/licenses/by-sa/2.0/ Creative Commons] license. You can use or modify ESAPI however you want, even include it in commercial products. | This project source code is licensed under the [http://en.wikipedia.org/wiki/BSD_license BSD license], which is very permissive and about as close to public domain as is possible. The project documentation is licensed under the [http://creativecommons.org/licenses/by-sa/2.0/ Creative Commons] license. You can use or modify ESAPI however you want, even include it in commercial products. | ||
− | The following organizations are a few of the many organizations that are starting to adopt ESAPI to secure their web applications: [http://www.americanexpress.com/ American Express], [http://www.apache.org/ Apache Foundation], [http://www.boozallen.com Booz Allen Hamilton], [http://www.aspectsecurity.com/ Aspect Security], [http://www. | + | The following organizations are a few of the many organizations that are starting to adopt ESAPI to secure their web applications: [http://www.americanexpress.com/ American Express], [http://www.apache.org/ Apache Foundation], [http://www.boozallen.com Booz Allen Hamilton], [http://www.aspectsecurity.com/ Aspect Security], [http://www.coraid.com Coraid], [http://www.thehartford.com/ The Hartford], [http://www.infinitecampus.com Infinite Campus], [http://www.lockheedmartin.com/ Lockheed Martin], [http://cwe.mitre.org/top25/index.html MITRE], [http://enterprise.spawar.navy.mil/ U.S. Navy - SPAWAR], [http://www.worldbank.org/ The World Bank], [http://www.sans.org/top25errors/ SANS Institute]. |
− | |||
− | |||
− | |||
− | |||
− | |||
− | | | + | Please let us know how your organization is using OWASP ESAPI. Include your name, organization's name, and brief description of how you are using it. The project co-leads can be reached [mailto:kevin.w.wall@gmail.com here] and [mailto:xeno6696@gmail.com here]. |
+ | | valign="top" style="padding-left:25px;width:300px;border-right: 1px dotted gray;padding-right:25px;" | | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
== Let's talk here == | == Let's talk here == | ||
Line 47: | Line 34: | ||
*[https://lists.owasp.org/mailman/listinfo/owasp-esapi-ruby esapi-ruby mailing list] | *[https://lists.owasp.org/mailman/listinfo/owasp-esapi-ruby esapi-ruby mailing list] | ||
*[https://lists.owasp.org/mailman/listinfo/owasp-esapi-swingset esapi-swingset mailing list] | *[https://lists.owasp.org/mailman/listinfo/owasp-esapi-swingset esapi-swingset mailing list] | ||
+ | *[http://groups.google.com/group/cfesapi esapi-coldfusion mailing list] | ||
+ | |||
+ | IRC Chat | ||
+ | |||
+ | If you would rather chat with us about your problem or thoughts - you can join us in our IRC channel using an [http://www.google.com/search?q=irc+client IRC Client] or using FreeNode's [http://webchat.freenode.net WebChat] client. | ||
+ | |||
+ | *Server: irc.freenode.net | ||
+ | *Channel: #esapi | ||
− | |||
== Got developer cycles? == | == Got developer cycles? == | ||
Line 54: | Line 48: | ||
The ESAPI project is always on the lookout for volunteers who are interested in contributing developer cycles. | The ESAPI project is always on the lookout for volunteers who are interested in contributing developer cycles. | ||
− | + | ||
− | |||
*ESAPI for other languages developer onboarding instructions -- coming soon! | *ESAPI for other languages developer onboarding instructions -- coming soon! | ||
− | + | == Project Sponsors == | |
− | == | ||
− | + | The ESAPI project is sponsored by {{MemberLinks|link=http://www.aspectsecurity.com|logo=Aspect_logo_owasp.jpg}} | |
− | + | |} | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | | | + | = Downloads = |
+ | <div style="width:100%;height:160px;border:0,margin:0;overflow: hidden;">[[File:OWASP_Project_Header.jpg|2400x160px|link=]]</div> | ||
− | == | + | {| style="padding: 0;margin:0;margin-top:10px;text-align:left;" |- |
+ | | valign="top" style="border-right: 1px dotted gray;padding-right:25px;" | | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
[[Image:Asvs-step1.jpg]]'''1. About ESAPI''' | [[Image:Asvs-step1.jpg]]'''1. About ESAPI''' | ||
Line 85: | Line 68: | ||
*Project presentation ([http://owasp-esapi-java.googlecode.com/files/OWASP%20ESAPI.ppt PowerPoint]) | *Project presentation ([http://owasp-esapi-java.googlecode.com/files/OWASP%20ESAPI.ppt PowerPoint]) | ||
*Video presentation ([http://www.youtube.com/watch?v=QAPD1jPn04g YouTube]) | *Video presentation ([http://www.youtube.com/watch?v=QAPD1jPn04g YouTube]) | ||
+ | |||
+ | | valign="top" style="padding-left:25px;width:33%;border-right: 1px dotted gray;padding-right:25px;" | | ||
[[Image:Asvs-step2.jpg]]'''2. Get ESAPI''' | [[Image:Asvs-step2.jpg]]'''2. Get ESAPI''' | ||
− | *[ | + | *[https://search.maven.org/#search|ga|1|esapi ESAPI for Java Downloads (binaries)] |
− | *[ | + | *[https://github.com/ESAPI/esapi-java-legacy ESAPI for Java (source)]<br> |
− | * | + | *[https://github.com/ESAPI/owasp-esapi-js ESAPI for Javascript]<br> |
− | * | + | |
− | * | + | '''No longer supported versions'''. If you absolutely need to download one of those, it is suggested that you search the [https://archive.org/ Internet Archive Wayback Machine] or [https://github.com/ GitHub] for someone who may have mirrored it: |
− | * | + | |
− | * | + | * ESAPI for .NET |
− | + | * ESAPI for Classic ASP | |
+ | * ESAPI for PHP | ||
+ | * ESAPI for ColdFusion & CFML | ||
+ | * ESAPI for Python | ||
+ | |||
+ | |||
+ | | valign="top" style="padding-left:25px;width:33%;" | | ||
− | |||
[[Image:Asvs-step3.jpg]]'''3. Learn ESAPI''' | [[Image:Asvs-step3.jpg]]'''3. Learn ESAPI''' | ||
Line 103: | Line 93: | ||
*The [[ESAPI Swingset|ESAPI Swingset]] sample application demonstrates how to leverage ESAPI to protect a web application. | *The [[ESAPI Swingset|ESAPI Swingset]] sample application demonstrates how to leverage ESAPI to protect a web application. | ||
*LAMP should be spelled LAMPE ([http://www.owasp.org/images/a/ac/LAMP_Should_be_Spelled_LAMPE.pdf PDF]) | *LAMP should be spelled LAMPE ([http://www.owasp.org/images/a/ac/LAMP_Should_be_Spelled_LAMPE.pdf PDF]) | ||
− | *ESAPI for Java interface documentation ([http:// | + | *ESAPI for Java interface documentation ([http://www.javadoc.io/doc/org.owasp.esapi/esapi/2.2.0.0 JavaDocs]) |
− | |||
|} | |} | ||
− | + | = What I did with ESAPI = | |
− | + | <div style="width:100%;height:160px;border:0,margin:0;overflow: hidden;">[[File:OWASP_Project_Header.jpg|link=]]</div> | |
− | = | ||
*I used ESAPI for Java with Google AppEngine. I used it for simple validation and encoding. --[mailto:jeff.williams@owasp.org Jeff] | *I used ESAPI for Java with Google AppEngine. I used it for simple validation and encoding. --[mailto:jeff.williams@owasp.org Jeff] | ||
Line 122: | Line 110: | ||
*I used ESAPI for Java's "Authenticator" to replace a spaghetti-like mechanism in a legacy financial services web application. In hindsight I should have used the application-specific "Adapter" pattern mentioned by Mike above. The organization also uses the ESAPI Encryptor as an interface to a hardware security module. --[mailto:roman.hustad@yahoo.com Roman] | *I used ESAPI for Java's "Authenticator" to replace a spaghetti-like mechanism in a legacy financial services web application. In hindsight I should have used the application-specific "Adapter" pattern mentioned by Mike above. The organization also uses the ESAPI Encryptor as an interface to a hardware security module. --[mailto:roman.hustad@yahoo.com Roman] | ||
− | *I use ESAPI for Java to educate developers about application security principals at several of the world’s largest organizations. --[mailto:jim.manico@owasp.org Jim]<br> | + | *I use ESAPI to be our security package for all our product, this way we can set one standard for all products. --[mailto:yairr@liveperson.com Yair] |
+ | |||
+ | *I use ESAPI for Java to educate developers about application security principals at several of the world’s largest organizations. --[mailto:jim.manico@owasp.org Jim]<br> | ||
+ | |||
+ | = Should I use ESAPI? = | ||
+ | <div style="width:100%;height:160px;border:0,margin:0;overflow: hidden;">[[File:OWASP_Project_Header.jpg|link=]]</div> | ||
+ | [NOTE: The heretical opinions on this ESAPI tab are 100% my own and do not necessarily reflect the rest of other ESAPI contributors or the OWASP staff, leadership, community. --kevin wall] | ||
+ | |||
+ | Or, specifically, "Should I use ESAPI for Java?" since that's the only one run by OWASP that still shows any semblance of life. | ||
+ | Maintenance activities is down, way down in fact of its peak development activities. Some of us are still trying and haven't given up and volunteers are still welcome. But without active contributors, projects make slow progress. | ||
+ | |||
+ | The first question to ask is, are you already using ESAPI in your project, and if so, do you have a lot vested in it? If so, then the answer to "Should I use ESAPI?" probably is "yes". The second question you should ask, if I'm using it, why am I not contributing to it in some manner? But we won't go there. | ||
+ | |||
+ | If you are starting out on a new project or trying for the first time to secure an existing project, then _before_ you consider ESAPI, you should consider these possible alternatives: | ||
+ | * Output encoding: [https://www.owasp.org/index.php/OWASP_Java_Encoder_Project OWASP Java Encoder Project] | ||
+ | * General HTML sanitization: [https://www.owasp.org/index.php/OWASP_Java_HTML_Sanitizer_Project OWASP Java HTML Sanitizer] | ||
+ | * Validation: [http://beanvalidation.org/ JSR-303/JSR-349 Bean Validation] | ||
+ | *Strong cryptography: [https://github.com/google/tink Google Tink], [https://github.com/google/keyczar Keyczar] | ||
+ | * Authentication / authorization: [https://shiro.apache.org/ Apache Shiro] | ||
+ | * CSRF protection: [https://www.owasp.org/index.php/Category:OWASP_CSRFGuard_Project OWASP CSRFGuard Project] or [https://www.owasp.org/index.php/CSRFProtector_Project OWASP CSRFProtector Project] | ||
+ | |||
+ | Note that this is not to suggest that ESAPI is dead, but rather to acknowledge the fact that it isn't being as well-maintained as most F500 companies would like for their enterprise software. There may be alternatives, such as companies that you can purchase ESAPI support from. Those are not being considered here for various reasons, not the least of which is to remain vendor neutral. Rather, instead these recommendations should be taken as possible alternatives to secure your application. It is not a perfect world that we live in, but I would be remiss as an appsec guy if I were to plug ESAPI over other good security solutions simply because of my contributions to / involvement with ESAPI. I think that ESAPI has it's place and I will do my best to maintain it, but not to the exclusion of my family or day job. If you would like to volunteer to help, you know where to find me. | ||
− | + | -[mailto:kevin.w.wall@gmail.com kevin wall] | |
+ | = Glossary = | ||
+ | <div style="width:100%;height:160px;border:0,margin:0;overflow: hidden;">[[File:OWASP_Project_Header.jpg|link=]]</div> | ||
[[Image:Asvs-letters.jpg]]'''ESAPI Terminology''' | [[Image:Asvs-letters.jpg]]'''ESAPI Terminology''' | ||
Line 144: | Line 155: | ||
<br> | <br> | ||
− | + | = Java EE = | |
+ | <div style="width:100%;height:160px;border:0,margin:0;overflow: hidden;">[[File:OWASP_Project_Header.jpg|link=]]</div> | ||
{{:GPC_Project_Details/OWASP_Enterprise_Security_API_Java_EE_Version | OWASP Project Identification Tab}} | {{:GPC_Project_Details/OWASP_Enterprise_Security_API_Java_EE_Version | OWASP Project Identification Tab}} | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
+ | = Project Details = | ||
+ | <div style="width:100%;height:160px;border:0,margin:0;overflow: hidden;">[[File:OWASP_Project_Header.jpg|link=]]</div> | ||
{{:GPC_Project_Details/OWASP_Enterprise_Security_API | OWASP Project Identification Tab}} | {{:GPC_Project_Details/OWASP_Enterprise_Security_API | OWASP Project Identification Tab}} | ||
__NOTOC__ <headertabs /> <br> | __NOTOC__ <headertabs /> <br> | ||
+ | |||
+ | {{OWASP Builders}} | ||
+ | [[Category:Popular]] | ||
+ | [[Category:SAMM-SA-3]] |
Latest revision as of 17:39, 28 June 2019
This project is part of the OWASP Builders community. Feel free to browse other projects within the Defenders, Builders, and Breakers communities. |
Pages in category "OWASP Enterprise Security API"
The following 27 pages are in this category, out of 27 total.
C
E
- EASPI
- ESAPI Swingset
- ESAPI
- ESAPI Access Control
- ESAPI ClassicASP Readme
- ESAPI ColdFusion CFML Readme
- ESAPI Contributions
- ESAPI DotNET Readme
- ESAPI Javadocs
- ESAPI JavaScript Readme
- ESAPI Mapping
- ESAPI Plan
- ESAPI Python Readme
- ESAPI Secure Coding Guideline
- ESAPI Specification
- ESAPI Summit
- ESAPI-Building
- ESAPI-BuildingWithEclipse