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 Application Security Verification Standard Project"

From OWASP
Jump to: navigation, search
(Classifications)
(Download)
 
(139 intermediate revisions by 20 users not shown)
Line 1: Line 1:
 
= Home =
 
= Home =
 +
<div style="width:100%;height:90px;border:0,margin:0;overflow: hidden;">[[File: flagship_big.jpg|link=https://www.owasp.org/index.php/OWASP_Project_Stages#tab=Flagship_Projects]]</div>
 +
{| style="padding: 0;margin:0;margin-top:10px;text-align:left;" |-
 +
| valign="top"  style="border-right: 1px dotted gray;padding-right:25px;" |
  
<div style="width:100%;height:160px;border:0,margin:0;overflow: hidden;">[[File:Asvs-header.jpg|link=]]</div>
+
== What is ASVS? ==
  
{| style="padding: 0;margin:0;margin-top:10px;text-align:left;" |-
+
The OWASP Application Security Verification Standard (ASVS) Project provides a basis for testing web application technical security controls and also provides developers with a list of requirements for secure development.
| valign="top"  style="border-right: 1px dotted gray;padding-right:25px;" |
 
  
 
The primary aim of the '''OWASP Application Security Verification Standard (ASVS) Project''' is to normalize the range in the coverage and level of rigor available in the market when it comes to performing Web application security verification using a commercially-workable open standard. The standard provides a basis for testing application technical security controls, as well as any technical security controls in the environment, that are relied on to protect against vulnerabilities such as Cross-Site Scripting (XSS) and SQL injection. This standard can be used to establish a level of confidence in the security of Web applications. The requirements were developed with the following objectives in mind:  
 
The primary aim of the '''OWASP Application Security Verification Standard (ASVS) Project''' is to normalize the range in the coverage and level of rigor available in the market when it comes to performing Web application security verification using a commercially-workable open standard. The standard provides a basis for testing application technical security controls, as well as any technical security controls in the environment, that are relied on to protect against vulnerabilities such as Cross-Site Scripting (XSS) and SQL injection. This standard can be used to establish a level of confidence in the security of Web applications. The requirements were developed with the following objectives in mind:  
Line 12: Line 14:
 
*'''Use during procurement''' - Provide a basis for specifying application security verification requirements in contracts.
 
*'''Use during procurement''' - Provide a basis for specifying application security verification requirements in contracts.
  
== Did you know...  ==
+
== OWASP ASVS 4.0 Released! ==
[[Image:Asvs-handshake.JPG]]'''ASVS Users'''
 
  
A broad range of companies and agencies around the globe have added ASVS to their software assurance tool boxes, including [http://www.aspectsecurity.com Aspect Security], [http://www.astyran.com Astyran], [http://www.boozallen.com Booz Allen Hamilton], [http://casabasecurity.com Casaba Security], [http://www.cgi.com/web/en/industries/governments/us_federal/services_solutions.htm CGI Federal], [http://denimgroup.com Denim Group], [http://etebaran.com Etebaran Informatics], [http://www.mindedsecurity.com Minded Security], [http://www.nixu.com Nixu], [http://www.pstestware.com/ ps_testware], [http://www.proactiverisk.com Proactive Risk], [http://quince.co.uk Quince Associates Limited (SeeMyData)], [http://www.serpro.gov.br/ Serviço Federal de Processamento de Dados (SERPRO)], [http://www.udistrital.edu.co/ Universidad Distrital Francisco José de Caldas] Organizations listed are not accredited by OWASP. Neither their products or services have been endorsed by OWASP. Use of ASVS may include for example providing verification services using the standard. Use of ASVS may also include for example performing internal evaluation of products with the OWASP ASVS in mind, and NOT making any claims of meeting any given level in the standard. Please let us know how your organization is using OWASP ASVS. Include your name, organization's name, and brief description of how you use the standard. The project lead can be reached [mailto:[email protected] here].
+
Get the new version of the ASVS 4.0 from the Downloads page.
<br><br>
 
 
 
| valign="top"  style="padding-left:25px;width:200px;border-right: 1px dotted gray;padding-right:25px;" |
 
 
 
== What is this? ==
 
 
 
The OWASP Application Security Verification Standard (ASVS) Project provides a basis for testing web application technical security controls.
 
  
 
== Email List ==
 
== Email List ==
Line 30: Line 24:
 
== Project Leaders ==
 
== Project Leaders ==
  
Sahba Kazerooni<br/>
+
* Daniel Cuthbert [mailto:Daniel.Cuthbert@owasp.org @]
Daniel Cuthbert
+
* Andrew van der Stock [mailto:[email protected] @]
 +
* Jim Manico [mailto:[email protected] @]
 +
* Mark Burnett
 +
* Josh C Grossman
  
== ASVS Translations ==
+
== Related Projects ==
  
[[Image:Asvs-writing.JPG]]
+
[[Image:Asvs-satellite.jpg]]'''OWASP Resources'''
  
The ASVS project is always on the lookout for volunteers who are interested in translating ASVS into another language.  
+
*[https://www.owasp.org/index.php/OWASP_Proactive_Controls OWASP Top Ten Proactive Controls (2018)]
 +
*[http://www.owasp.org/index.php/Category:OWASP_Top_Ten_Project OWASP Top Ten Risks (2017)]
 +
*[https://www.owasp.org/index.php/OWASP_Cheat_Sheet_Series OWASP Cheatsheet Series]
  
*[http://owasp-project-management.googlecode.com/svn/trunk/documentation/asvs-translating.pdf Translation Onboarding Instructions].
 
  
 
| valign="top"  style="padding-left:25px;width:200px;" |
 
| valign="top"  style="padding-left:25px;width:200px;" |
 +
 +
== GitHub Repo ==
 +
 +
[https://github.com/OWASP/ASVS/tree/master/4.0 ASVS GitHub Repo]
 +
 +
== Download ==
 +
 +
ASVS 4.0
 +
 +
* [https://github.com/OWASP/ASVS/raw/master/4.0/OWASP%20Application%20Security%20Verification%20Standard%204.0-en.pdf English PDF (1.1 MB)]
 +
* [https://github.com/OWASP/ASVS/raw/master/4.0/OWASP%20Application%20Security%20Verification%20Standard%204.0-en.docx English Word (560 kB)]
 +
* [https://github.com/OWASP/ASVS/raw/master/4.0/OWASP%20Application%20Security%20Verification%20Standard%204.0-en.csv English CSV (65 kB)]
  
 
== News and Events ==
 
== News and Events ==
* [March 27 2014] New Wiki Template!
+
 
 +
* [1 March 2019] ASVS 4.0 released!
 +
* [9 March 2018] [https://docs.google.com/spreadsheets/d/1ic7gsib--Cn4ujrA8rhvzuUmMFpQ2Jkl96SZDCEtqJg/edit?ts=5a6bafe1#gid=950526877 OWASP Application Security Verification Standard 3.1 Spreadsheet] created by August Detlefsen
 +
* [29 June 2016] [[Media:OWASP_Application_Security_Verification_Standard_3.0.1.pdf|Version 3.0.1]] released!
 +
* [9 Oct 2015] Version 3.0 released
 +
* [20 May 2015] "First Cut" Version 3.0 released
 +
* [11 Aug 2014] Version 2.0 released
  
 
==Classifications==
 
==Classifications==
Line 62: Line 78:
 
|}
 
|}
  
== Related resources ==
+
= Downloads =
 +
 
 +
== GitHub Repo ==
 +
 
 +
[https://github.com/OWASP/ASVS/tree/master/4.0 ASVS GitHub Repo]
 +
 
 +
== Download ==
 +
 
 +
ASVS 4.0 (GitHub hosted)
 +
 
 +
* [https://github.com/OWASP/ASVS/raw/master/4.0/OWASP%20Application%20Security%20Verification%20Standard%204.0-en.pdf English PDF (1.1 MB)]
 +
* [https://github.com/OWASP/ASVS/raw/master/4.0/OWASP%20Application%20Security%20Verification%20Standard%204.0-en.docx English Word (560 kB)]
 +
* [https://github.com/OWASP/ASVS/raw/master/4.0/OWASP%20Application%20Security%20Verification%20Standard%204.0-en.csv English CSV (65 kB)]
 +
 
 +
Translations are coming for Hindi. If you want ASVS in your language, please contact the leadership directly or on Slack, and let's make it happen!
 +
 
 +
ASVS 4.0 (OWASP.org hosted)
 +
 
 +
* OWASP ASVS v4.0 English [[Media:OWASP_Application_Security_Verification_Standard_4.0-en.pdf|PDF]]
 +
* OWASP ASVS v4.0 English [[Media:OWASP_Application_Security_Verification_Standard_4.0-en.docx|Word]]
 +
* OWASP ASVS v4.0 Persian [[Media:OWASP Application Security Verification Standard 4.0-FA_.pdf|PDF]]
 +
 
 +
= Acknowledgements =
 +
 
 +
== Volunteers ==
  
[[Image:Asvs-satellite.jpg]]'''OWASP Resources'''  
+
=== Version 3 (2015) ===
 +
 
 +
Project Leaders
 +
 
 +
*Daniel Cuthbert
 +
*Andrew van der Stock
 +
 
 +
Lead Author
 +
*Jim Manico
 +
 
 +
Other reviewers and contributors
 +
*Boy Baukema
 +
*Ari Kesäniemi
 +
*Colin Watson
 +
*François-Eric Guyomarc’h
 +
*Cristinel Dumitru
 +
*James Holland
 +
*Gary Robinson
 +
*Stephen de Vries
 +
*Glenn Ten Cate
 +
*Riccardo Ten Cate
 +
*Martin Knobloch
 +
*Abhinav Sejpal
 +
*David Ryan
 +
*Steven van der Baan
 +
*Ryan Dewhurst
 +
*Raoul Endres
 +
*Roberto Martelloni
 +
 
 +
=== Version 2 (2014) ===
 +
 
 +
Project leaders
 +
*Sahba Kazerooni
 +
*Daniel Cuthbert
 +
 
 +
Lead authors
 +
*Andrew van der Stock
 +
*Sahba Kazerooni
 +
*Daniel Cuthbert
 +
*Krishna Raja
 +
 
 +
Other reviewers and contributors
 +
*Jerome Athias
 +
*Boy Baukema
 +
*Archangel Cuison
 +
*Sebastien.Deleersnyder
 +
*Antonio Fontes
 +
*Evan Gaustad
 +
*Safuat Hamdy
 +
*Ari Kesäniemi
 +
*Scott Luc
 +
*Jim Manico
 +
*Mait Peekma
 +
*Pekka Sillanpää
 +
*Jeff Sergeant
 +
*Etienne Stalmans
 +
*Colin Watson
 +
*Dr. Emin İslam Tatlı
 +
 
 +
Translators
 +
*Abbas Javan Jafari (Persian)
 +
*Sajjad Pourali (Persian)
 +
 
 +
 
 +
=== Version 2009 ===
 +
 
 +
Project leader
 +
*Mike Boberski
 +
 
 +
Lead authors
 +
*Mike Boberski
 +
*Jeff Williams
 +
*Dave Wichers
 +
 
 +
Other reviewers and contributors
 +
 
 +
Pierre Parrend (OWASP Summer of Code), Andrew van der Stock, Nam Nguyen, John Martin, Gaurang Shah, Theodore Winograd, Stan Wisseman, Barry Boyd, Steve Coyle, Paul Douthit, Ken Huang, Dave Hausladen, Mandeep Khera Scott Matsumoto, John Steven, Stephen de Vries, Dan Cornell, Shouvik Bardhan, Dr. Sarbari Gupta, Eoin Keary, Richard Campbell, Matt Presson, Jeff LoSapio, Liz Fong, George Lawless, Dave van Stein, Terrie Diaz, Ketan Dilipkumar Vyas, Bedirhan Urgun, Dr. Thomas Braun, Colin Watson, Jeremiah Grossman.
 +
 
 +
== OWASP Summer of Code 2008 ==
 +
 
 +
The OWASP Foundation sponsored the OWASP Application Security Verification Standard Project during the OWASP Summer of Code 2008.
 +
 
 +
= Glossary =
 +
 
 +
[[Image:Asvs-letters.jpg]]'''ASVS Terminology'''
 +
 
 +
*'''Access Control''' – A means of restricting access to files, referenced functions, URLs, and data based on the identity of users and/or groups to which they belong.
 +
*'''Application Component''' – An individual or group of source files, libraries, and/or executables, as defined by the verifier for a particular application.
 +
*'''Application Security''' – Application-level security focuses on the analysis of components that comprise the application layer of the Open Systems Interconnection Reference Model (OSI Model), rather than focusing on for example the underlying operating system or connected networks.
 +
*'''Application Security Verification''' – The technical assessment of an application against the OWASP ASVS.
 +
*'''Application Security Verification Report''' – A report that documents the overall results and supporting analysis produced by the verifier for a particular application.
 +
*'''Application Security Verification Standard (ASVS)''' – An OWASP standard that defines four levels of application security verification for applications.
 +
*'''Authentication''' – The verification of the claimed identity of an application user.
 +
*'''Automated Verification''' – The use of automated tools (either dynamic analysis tools, static analysis tools, or both) that use vulnerability signatures to find problems.
 +
*'''Back Doors''' – A type of malicious code that allows unauthorized access to an application.
 +
*'''Blacklist''' – A list of data or operations that are not permitted, for example a list of characters that are not allowed as input.
 +
*'''Common Criteria (CC)''' – A multipart standard that can be used as the basis for the verification of the design and implementation of security controls in IT products.
 +
*'''Communication Security''' – The protection of application data when it is transmitted between application components, between clients and servers, and between external systems and the application.
 +
*'''Design Verification''' – The technical assessment of the security architecture of an application.
 +
*'''Internal Verification''' – The technical assessment of specific aspects of the security architecture of an application as defined in the OWASP ASVS.
 +
*'''Cryptographic module''' – Hardware, software, and/or firmware that implements cryptographic algorithms and/or generates cryptographic keys.
 +
*'''Denial of Service (DOS) Attacks''' – The flooding of an application with more requests than it can handle.
 +
*'''Dynamic Verification''' – The use of automated tools that use vulnerability signatures to find problems during the execution of an application.
 +
*'''Easter Eggs''' – A type of malicious code that does not run until a specific user input event occurs.
 +
*'''External Systems''' – A server-side application or service that is not part of the application.
 +
*'''FIPS 140-2''' – A standard that can be used as the basis for the verification of the design and implementation of cryptographic modules
 +
*'''Input Validation''' – The canonicalization and validation of untrusted user input.
 +
*'''Malicious Code''' – Code introduced into an application during its development unbeknownst to the application owner which circumvents the application’s intended security policy. Not the same as malware such as a virus or worm!
 +
*'''Malware''' – Executable code that is introduced into an application during runtime without the knowledge of the application user or administrator.
 +
*'''Open Web Application Security Project (OWASP)''' – The Open Web Application Security Project (OWASP) is a worldwide free and open community focused on improving the security of application software. Our mission is to make application security "visible," so that people and organizations can make informed decisions about application security risks. See: http://www.owasp.org/
 +
*'''Output Validation''' – The canonicalization and validation of application output to Web browsers and to external systems.
 +
*'''OWASP Enterprise Security API (ESAPI)''' – A free and open collection of all the security methods that developers need to build secure Web applications. See: http://www.owasp.org/index.php/ESAPI
 +
*'''OWASP Risk Rating Methodology''' – A risk rating methodology that has been customized for application security. See: http://www.owasp.org/index.php/How_to_value_the_real_risk
 +
*'''OWASP Testing Guide''' – A document designed to help organizations understand what comprises a testing program, and to help them identify the steps needed to build and operate that testing program. See: http://www.owasp.org/index.php/Category:OWASP_Testing_Project
 +
*'''OWASP Top Ten''' – A document that represents a broad consensus about what the most critical Web application security flaws are. See: http://www.owasp.org/index.php/Top10
 +
*'''Positive''' – See whitelist.
 +
*'''Salami Attack''' – A type of malicious code that is used to redirect small amounts of money without detection in financial transactions.
 +
*'''Security Architecture''' – An abstraction of an application’s design that identifies and describes where and how security controls are used, and also identifies and describes the location and sensitivity of both user and application data.
 +
*'''Security Control''' – A function or component that performs a security check (e.g. an access control check) or when called results in a security effect (e.g. generating an audit record).
 +
*'''Security Configuration''' – The runtime configuration of an application that affects how security controls are used.
 +
*'''Static Verification''' – The use of automated tools that use vulnerability signatures to find problems in application source code.
 +
*'''Target of Verification (TOV)''' – If you are performing an application security verification according to the OWASP ASVS requirements, the verification will be of a particular application. This application is called the "Target of Verification" or simply the TOV.
 +
*'''Threat Modeling''' - A technique consisting of developing increasingly refined security architectures to identify threat agents, security zones, security controls, and important technical and business assets.
 +
*'''Time Bomb''' – A type of malicious code that does not run until a preconfigured time or date elapses.
 +
*'''Verifier''' - The person or team that is reviewing an application against the OWASP ASVS requirements.
 +
*'''Whitelist''' – A list of permitted data or operations, for example a list of characters that are allowed to perform input validation.
 +
 
 +
= ASVS Users  =
 +
[[Image:Asvs-handshake.JPG]]
 +
 
 +
A broad range of companies and agencies around the globe have added ASVS to their software assurance tool boxes, including [http://www.aspectsecurity.com Aspect Security], [http://www.astyran.com Astyran], [http://www.boozallen.com Booz Allen Hamilton], [http://casabasecurity.com Casaba Security], [http://www.cgi.com/web/en/industries/governments/us_federal/services_solutions.htm CGI Federal], [http://denimgroup.com Denim Group], [http://etebaran.com Etebaran Informatics], [http://www.mindedsecurity.com Minded Security], [http://www.nixu.com Nixu], [http://www.pstestware.com/ ps_testware], [http://www.proactiverisk.com Proactive Risk], [http://quince.co.uk Quince Associates Limited (SeeMyData)], [http://www.serpro.gov.br/ Serviço Federal de Processamento de Dados (SERPRO)], [http://www.udistrital.edu.co/ Universidad Distrital Francisco José de Caldas] Organizations listed are not accredited by OWASP. Neither their products or services have been endorsed by OWASP. Use of ASVS may include for example providing verification services using the standard. Use of ASVS may also include for example performing internal evaluation of products with the OWASP ASVS in mind, and NOT making any claims of meeting any given level in the standard. Please let us know how your organization is using OWASP ASVS. Include your name, organization's name, and brief description of how you use the standard. The project lead can be reached [mailto:[email protected] here].
 +
 
 +
= Precedents-Interpretations =
 +
 
 +
'''PI-0001: Are there levels between the levels?'''
 +
 
 +
*Issue: Are there levels between the levels for the cases where "The specification for an application may require OWASP ASVS Level N, but it could also include other additional detailed requirements such as from a higher ASVS level"?
 +
*Resolution: No. Use of alternate level definitions or notations such as "ASVS Level 1B+" is discouraged.
 +
*References: ASVS section "Application Security Verification Levels"
 +
 
 +
'''PI-0002: Is use of a master key simply another level of indirection?'''
 +
 
 +
*Issue: If a master key is stored as plaintext, isn't using a master key simply another level of indirection?
 +
*Resolution: No. There is a strong rationale for having a "master key" stored in a secure location that is used to encrypt all other secrets. In many applications, there are lots of secrets stored in many different locations. This greatly increases the likelihood that one of them will be compromised. Having a single master key makes managing the protection considerably simpler and is not simply a level of indirection.
 +
*References: ASVS verification requirement V2.14
 +
 
 +
'''PI-0003: What is a "TOV" or "Target of Verification"?'''
 +
 
 +
*Issue: New terminology
 +
*Resolution: If you are performing an application security verification according to ASVS, the verification will be of a particular application. This application is called the "Target of Verification" or simply the TOV. The TOV should be identified in verification documentation as follows:
 +
**TOV Identification – &lt;name and version of the application&gt; or &lt;Application name&gt;, &lt;application version&gt;, dynamic testing was performed in a staging environment, not the production environment
 +
**TOV Developer – &lt;insert name of the developer or verification customer&gt;
 +
*References: ASVS section "Approach"
 +
 
 +
= Internationalization =
 +
 
 +
[[Image:Asvs-writing.JPG]]
 +
If you can help with translations, please download the latest draft here:
 +
 
 +
https://github.com/OWASP/ASVS
 +
 
 +
If there are any incomprehensible English idiom or phrases in there, please don't hesitate to ask for clarification, because if it's hard to translate, it's almost certainly wrong in English as well. We recommend logging translation issues in GitHub, too, so please make yourself known.
 +
 
 +
Translations are coordinated through OWASP's Crowd In account, so you don't have to do the entire thing yourself.
 +
 
 +
https://crowdin.com/project/owasp-asvs/
 +
 
 +
You don't HAVE to use Crowd In, but it would be nice to indicate to other native speakers of your language that you are willing to work together. This is a 70 page document, and in all honesty, will take a dedicated person a week or more to translate, so please please please work together rather than apart. You have full access to the original document and the original images, so you have everything I have.
 +
 
 +
= Archive - Previous Version =
 +
 
 +
'''*Please note that the current version of ASVS is v4.0.  The information on this page is for archival purposes only.*'''
 +
 
 +
'''Application Security Verification Standard 3.0.1 '''
 +
 
 +
== ASVS 3.0.1 in English ==
 +
* [[Media:OWASP_Application_Security_Verification_Standard_3.0.1.pdf|Download PDF - 1.7 MB]]
 +
* [[Media:OWASP_Application_Security_Verification_Standard_3.0.1.docx|Download Word - 835 kB]]
 +
 
 +
== ASVS 3.0.1 in Spanish==
 +
* [[Media:Estándar_de_Verificación_de_Seguridad_en_Aplicaciones_3.0.1.pdf|Download PDF - 1.7 MB]]
 +
* [[Media:Estándar_de_Verificación_de_Seguridad_en_Aplicaciones_3.0.1.docx|Download Word - 835 kB]]
 +
 
 +
== ASVS 3.0.1 in Polish==
 +
* [[Media:OWASP Application Security Verification Standard 3.0.1 PL.pdf|Download PDF - 1.5 MB]]
 +
 
 +
== ASVS 3.0.1 in Persian==
 +
* [[Media:OWASP ASVS 3.0.1 (Persian).pdf|Download PDF - 2.84 MB]]
 +
 
 +
We are looking for translators for this version. If you can help us, please contact the project mail list!
 +
 
 +
'''Legacy Application Security Verification Standard 3.0'''
 +
 
 +
== ASVS 3.0 in English ==
 +
* [[Media:OWASPApplicationSecurityVerificationStandard3.0.pdf|download PDF - 1.2 MB]]
 +
* [[Media:ASVS-excel.xlsx|ASVS 3.0 excel sheet  - 39 kB]]
 +
 
 +
== Older versions ==
 +
 
 +
'''Application Security Verification Standard 2.0 (final)'''
 +
 
 +
* ASVS 2.0 in English ([[Media:OWASP_ASVS_Version_2.pdf|download PDF - 1.6 MB]])
 +
* ASVS 2.0 in English ([[Media:OWASP_ASVS_Version_2.docx|download Word - 1.0MB]])
 +
* ASVS 2.0 in Persian ([[Media:OWASP_ASVS_Version_2_Persian.pdf|download PDF - 1.6MB]])
 +
* ASVS 2.0 in Polish (checklist) ([[Media:Asvs_2_PL.xlsx|download Excel]])
 +
 
 +
'''Application Security Verification Standard 1.0 - 2009'''
 +
 
 +
* ASVS 1.0 Final (English) ([[Media:OWASP_ASVS_2009_Web_App_Std_Release.pdf|download PDF - 2.5 MB]])
 +
* ASVS 1.0 Final (English) ([[Media:OWASP_ASVS_2009_Web_App_Std_Release.doc|download Word - 2.3 MB]])
 +
 
 +
[[Image:Asvs-step1.jpg]]'1. About ASVS 1.0'
 +
 
 +
*Video presentation in English [https://www.youtube.com/watch?v=Ba6ncpIfaJA (YouTube)]
 +
*ASVS vs. WASC et al [http://www.owasp.org/index.php/ASVS_vs_WASC_Et_Al (Wiki)]
 +
 
 +
[[Image:Asvs-step2.jpg]]'2. Get ASVS 1.0'
 +
 
 +
*ASVS in Bahasa Indonesia (Indonesian language) ([http://owasp-asvs.googlecode.com/files/asvs-webapp-release-2009-id.pdf PDF])
 +
*ASVS in Bahasa Malaysia (Malay) (Currently under development!)
 +
*ASVS in Chinese(Currently under development!)
 +
*ASVS in English ([http://www.owasp.org/images/4/4e/OWASP_ASVS_2009_Web_App_Std_Release.pdf PDF], [http://www.owasp.org/images/3/35/OWASP_ASVS_2009_Web_App_Std_Release.doc Word], [http://code.google.com/p/owasp-asvs/wiki/ASVS '''Online'''], [http://owasp-asvs.googlecode.com/svn/trunk/documentation/asvs-xml.zip XML])
 +
*ASVS in French ([http://owasp-asvs.googlecode.com/svn/trunk/documentation/asvs-webapp-release-2009-fr.pdf PDF], [http://owasp-asvs.googlecode.com/svn/trunk/documentation/asvs-webapp-release-2009-fr.odt OpenOffice])
 +
*ASVS in German ([http://owasp-asvs.googlecode.com/svn/trunk/documentation/asvs-webapp-release-2009-de.pdf PDF], [http://owasp-asvs.googlecode.com/svn/trunk/documentation/asvs-webapp-release-2009-de.doc Word])
 +
*ASVS in Hungarian (Currently under development!)
 +
*ASVS in Japanese ([http://owasp-asvs.googlecode.com/svn/trunk/documentation/asvs-webapp-release-2009-jp.pdf PDF], [http://owasp-asvs.googlecode.com/svn/trunk/documentation/asvs-webapp-release-2009-jp.doc Word])
 +
*ASVS in Persian (Farsi) ([http://abiusx.com/archive/document/OWASP-ASVS-fa-20111115.pdf PDF]) beta 0.7
 +
*ASVS in Polish ([http://owasp-asvs.googlecode.com/files/asvs-webapp-release-2009-pl.pdf PDF])
 +
*ASVS in Portuguese-Brazil ([http://owasp-asvs.googlecode.com/files/asvs-webapp-release-2009-pt-br.pdf PDF])
 +
*ASVS in Spanish (Currently under development!)
 +
*ASVS in Thai (Currently under development!)
 +
 
 +
[[Image:Asvs-step3.jpg]]'3. Learn ASVS 1.0'  
  
*[http://www.owasp.org/index.php/Category:OWASP_Top_Ten_Project OWASP Top Ten]  
+
*ASVS Article: Getting Started Using ASVS ([http://www.owasp.org/images/f/f8/OWASP_ASVS_Article_-_Getting_Started_Using_ASVS.pdf PDF])
*[http://www.owasp.org/index.php/Category:OWASP_Guide_Project OWASP Development Guide]  
+
*ASVS Article: Code Reviews and Other Verification Activities: USELESS Unless Acted Upon IMMEDIATELY [http://www.owasp.org/index.php/Code_Reviews_and_Other_Verification_Activities:_USELESS_Unless_Acted_Upon_IMMEDIATELY (Wiki)]
*[http://www.owasp.org/index.php/Common_OWASP_Numbering OWASP Common Numbering]
+
*ASVS Article: Agile Software Development: Don't Forget EVIL User Stories ([http://www.owasp.org/index.php/Agile_Software_Development:_Don%27t_Forget_EVIL_User_Stories Wiki])
 +
*ASVS Article: Man vs. Code ([http://www.owasp.org/index.php/Man_vs._Code Wiki])
 +
*ASVS Article: Getting started designing for a level of assurance ([http://www.owasp.org/images/0/01/Getting_started_designing_for_a_level_of_assurance.pdf PDF])
 +
*ASVS Template: Sample verification fee schedule template ([http://www.owasp.org/index.php/Image:Sample_ASVS_Fee_Schedule_Template.xls Excel])
 +
*ASVS Template: Sample verification report template ([http://www.owasp.org/index.php/Image:Sample_ASVS_Report_Template.doc Word])
 +
*ASVS Training: An ASVS training presentation ([http://www.owasp.org/index.php/Image:OWASP_AU_Secure_Architecture_and_Coding.ppt PowerPoint])
 +
*ASVS Presentation: Executive-Level Presentation ([http://www.owasp.org/images/9/99/About_OWASP_ASVS_Executive_Presentation.ppt PowerPoint])
 +
*ASVS Presentation: Presentation Abstract ([http://www.owasp.org/images/1/10/OWASP_ASVS_Presentation_Abstract.doc Word])
 +
*Articles [http://www.owasp.org/index.php/Category:OWASP_Application_Security_Verification_Standard_Project#Articles_Below_-_More_About_ASVS_and_Using_It (More About ASVS and Using It)]
  
= Project About  =
 
{{:Projects/OWASP Application Security Verification Standard Project| Project About}}
 
  
 
__NOTOC__ <headertabs />
 
__NOTOC__ <headertabs />
Line 79: Line 357:
 
[[Category:OWASP_Download]]
 
[[Category:OWASP_Download]]
 
[[Category:OWASP_Release_Quality_Document|OWASP Stable Quality Document]]
 
[[Category:OWASP_Release_Quality_Document|OWASP Stable Quality Document]]
 +
[[Category:SAMM-CR-1]]
 +
[[Category:SAMM-DR-2]]
 +
[[Category:SAMM-ST-3]]

Latest revision as of 16:01, 25 October 2019

Flagship big.jpg

What is ASVS?

The OWASP Application Security Verification Standard (ASVS) Project provides a basis for testing web application technical security controls and also provides developers with a list of requirements for secure development.

The primary aim of the OWASP Application Security Verification Standard (ASVS) Project is to normalize the range in the coverage and level of rigor available in the market when it comes to performing Web application security verification using a commercially-workable open standard. The standard provides a basis for testing application technical security controls, as well as any technical security controls in the environment, that are relied on to protect against vulnerabilities such as Cross-Site Scripting (XSS) and SQL injection. This standard can be used to establish a level of confidence in the security of Web applications. The requirements were developed with the following objectives in mind:

  • Use as a metric - Provide application developers and application owners with a yardstick with which to assess the degree of trust that can be placed in their Web applications,
  • Use as guidance - Provide guidance to security control developers as to what to build into security controls in order to satisfy application security requirements, and
  • Use during procurement - Provide a basis for specifying application security verification requirements in contracts.

OWASP ASVS 4.0 Released!

Get the new version of the ASVS 4.0 from the Downloads page.

Email List

Asvs-bulb.jpg Project Email List

Project Leaders

  • Daniel Cuthbert @
  • Andrew van der Stock @
  • Jim Manico @
  • Mark Burnett
  • Josh C Grossman

Related Projects

Asvs-satellite.jpgOWASP Resources


GitHub Repo

ASVS GitHub Repo

Download

ASVS 4.0

News and Events

Classifications

Owasp-flagship-trans-85.png Owasp-builders-small.png
Owasp-defenders-small.png
Cc-button-y-sa-small.png
Project Type Files DOC.jpg

GitHub Repo

ASVS GitHub Repo

Download

ASVS 4.0 (GitHub hosted)

Translations are coming for Hindi. If you want ASVS in your language, please contact the leadership directly or on Slack, and let's make it happen!

ASVS 4.0 (OWASP.org hosted)

  • OWASP ASVS v4.0 English PDF
  • OWASP ASVS v4.0 English Word
  • OWASP ASVS v4.0 Persian PDF

Volunteers

Version 3 (2015)

Project Leaders

  • Daniel Cuthbert
  • Andrew van der Stock

Lead Author

  • Jim Manico

Other reviewers and contributors

  • Boy Baukema
  • Ari Kesäniemi
  • Colin Watson
  • François-Eric Guyomarc’h
  • Cristinel Dumitru
  • James Holland
  • Gary Robinson
  • Stephen de Vries
  • Glenn Ten Cate
  • Riccardo Ten Cate
  • Martin Knobloch
  • Abhinav Sejpal
  • David Ryan
  • Steven van der Baan
  • Ryan Dewhurst
  • Raoul Endres
  • Roberto Martelloni

Version 2 (2014)

Project leaders

  • Sahba Kazerooni
  • Daniel Cuthbert

Lead authors

  • Andrew van der Stock
  • Sahba Kazerooni
  • Daniel Cuthbert
  • Krishna Raja

Other reviewers and contributors

  • Jerome Athias
  • Boy Baukema
  • Archangel Cuison
  • Sebastien.Deleersnyder
  • Antonio Fontes
  • Evan Gaustad
  • Safuat Hamdy
  • Ari Kesäniemi
  • Scott Luc
  • Jim Manico
  • Mait Peekma
  • Pekka Sillanpää
  • Jeff Sergeant
  • Etienne Stalmans
  • Colin Watson
  • Dr. Emin İslam Tatlı

Translators

  • Abbas Javan Jafari (Persian)
  • Sajjad Pourali (Persian)


Version 2009

Project leader

  • Mike Boberski

Lead authors

  • Mike Boberski
  • Jeff Williams
  • Dave Wichers

Other reviewers and contributors

Pierre Parrend (OWASP Summer of Code), Andrew van der Stock, Nam Nguyen, John Martin, Gaurang Shah, Theodore Winograd, Stan Wisseman, Barry Boyd, Steve Coyle, Paul Douthit, Ken Huang, Dave Hausladen, Mandeep Khera Scott Matsumoto, John Steven, Stephen de Vries, Dan Cornell, Shouvik Bardhan, Dr. Sarbari Gupta, Eoin Keary, Richard Campbell, Matt Presson, Jeff LoSapio, Liz Fong, George Lawless, Dave van Stein, Terrie Diaz, Ketan Dilipkumar Vyas, Bedirhan Urgun, Dr. Thomas Braun, Colin Watson, Jeremiah Grossman.

OWASP Summer of Code 2008

The OWASP Foundation sponsored the OWASP Application Security Verification Standard Project during the OWASP Summer of Code 2008.

Asvs-letters.jpgASVS Terminology

  • Access Control – A means of restricting access to files, referenced functions, URLs, and data based on the identity of users and/or groups to which they belong.
  • Application Component – An individual or group of source files, libraries, and/or executables, as defined by the verifier for a particular application.
  • Application Security – Application-level security focuses on the analysis of components that comprise the application layer of the Open Systems Interconnection Reference Model (OSI Model), rather than focusing on for example the underlying operating system or connected networks.
  • Application Security Verification – The technical assessment of an application against the OWASP ASVS.
  • Application Security Verification Report – A report that documents the overall results and supporting analysis produced by the verifier for a particular application.
  • Application Security Verification Standard (ASVS) – An OWASP standard that defines four levels of application security verification for applications.
  • Authentication – The verification of the claimed identity of an application user.
  • Automated Verification – The use of automated tools (either dynamic analysis tools, static analysis tools, or both) that use vulnerability signatures to find problems.
  • Back Doors – A type of malicious code that allows unauthorized access to an application.
  • Blacklist – A list of data or operations that are not permitted, for example a list of characters that are not allowed as input.
  • Common Criteria (CC) – A multipart standard that can be used as the basis for the verification of the design and implementation of security controls in IT products.
  • Communication Security – The protection of application data when it is transmitted between application components, between clients and servers, and between external systems and the application.
  • Design Verification – The technical assessment of the security architecture of an application.
  • Internal Verification – The technical assessment of specific aspects of the security architecture of an application as defined in the OWASP ASVS.
  • Cryptographic module – Hardware, software, and/or firmware that implements cryptographic algorithms and/or generates cryptographic keys.
  • Denial of Service (DOS) Attacks – The flooding of an application with more requests than it can handle.
  • Dynamic Verification – The use of automated tools that use vulnerability signatures to find problems during the execution of an application.
  • Easter Eggs – A type of malicious code that does not run until a specific user input event occurs.
  • External Systems – A server-side application or service that is not part of the application.
  • FIPS 140-2 – A standard that can be used as the basis for the verification of the design and implementation of cryptographic modules
  • Input Validation – The canonicalization and validation of untrusted user input.
  • Malicious Code – Code introduced into an application during its development unbeknownst to the application owner which circumvents the application’s intended security policy. Not the same as malware such as a virus or worm!
  • Malware – Executable code that is introduced into an application during runtime without the knowledge of the application user or administrator.
  • Open Web Application Security Project (OWASP) – The Open Web Application Security Project (OWASP) is a worldwide free and open community focused on improving the security of application software. Our mission is to make application security "visible," so that people and organizations can make informed decisions about application security risks. See: http://www.owasp.org/
  • Output Validation – The canonicalization and validation of application output to Web browsers and to external systems.
  • OWASP Enterprise Security API (ESAPI) – A free and open collection of all the security methods that developers need to build secure Web applications. See: http://www.owasp.org/index.php/ESAPI
  • OWASP Risk Rating Methodology – A risk rating methodology that has been customized for application security. See: http://www.owasp.org/index.php/How_to_value_the_real_risk
  • OWASP Testing Guide – A document designed to help organizations understand what comprises a testing program, and to help them identify the steps needed to build and operate that testing program. See: http://www.owasp.org/index.php/Category:OWASP_Testing_Project
  • OWASP Top Ten – A document that represents a broad consensus about what the most critical Web application security flaws are. See: http://www.owasp.org/index.php/Top10
  • Positive – See whitelist.
  • Salami Attack – A type of malicious code that is used to redirect small amounts of money without detection in financial transactions.
  • Security Architecture – An abstraction of an application’s design that identifies and describes where and how security controls are used, and also identifies and describes the location and sensitivity of both user and application data.
  • Security Control – A function or component that performs a security check (e.g. an access control check) or when called results in a security effect (e.g. generating an audit record).
  • Security Configuration – The runtime configuration of an application that affects how security controls are used.
  • Static Verification – The use of automated tools that use vulnerability signatures to find problems in application source code.
  • Target of Verification (TOV) – If you are performing an application security verification according to the OWASP ASVS requirements, the verification will be of a particular application. This application is called the "Target of Verification" or simply the TOV.
  • Threat Modeling - A technique consisting of developing increasingly refined security architectures to identify threat agents, security zones, security controls, and important technical and business assets.
  • Time Bomb – A type of malicious code that does not run until a preconfigured time or date elapses.
  • Verifier - The person or team that is reviewing an application against the OWASP ASVS requirements.
  • Whitelist – A list of permitted data or operations, for example a list of characters that are allowed to perform input validation.

Asvs-handshake.JPG

A broad range of companies and agencies around the globe have added ASVS to their software assurance tool boxes, including Aspect Security, Astyran, Booz Allen Hamilton, Casaba Security, CGI Federal, Denim Group, Etebaran Informatics, Minded Security, Nixu, ps_testware, Proactive Risk, Quince Associates Limited (SeeMyData), Serviço Federal de Processamento de Dados (SERPRO), Universidad Distrital Francisco José de Caldas Organizations listed are not accredited by OWASP. Neither their products or services have been endorsed by OWASP. Use of ASVS may include for example providing verification services using the standard. Use of ASVS may also include for example performing internal evaluation of products with the OWASP ASVS in mind, and NOT making any claims of meeting any given level in the standard. Please let us know how your organization is using OWASP ASVS. Include your name, organization's name, and brief description of how you use the standard. The project lead can be reached here.

PI-0001: Are there levels between the levels?

  • Issue: Are there levels between the levels for the cases where "The specification for an application may require OWASP ASVS Level N, but it could also include other additional detailed requirements such as from a higher ASVS level"?
  • Resolution: No. Use of alternate level definitions or notations such as "ASVS Level 1B+" is discouraged.
  • References: ASVS section "Application Security Verification Levels"

PI-0002: Is use of a master key simply another level of indirection?

  • Issue: If a master key is stored as plaintext, isn't using a master key simply another level of indirection?
  • Resolution: No. There is a strong rationale for having a "master key" stored in a secure location that is used to encrypt all other secrets. In many applications, there are lots of secrets stored in many different locations. This greatly increases the likelihood that one of them will be compromised. Having a single master key makes managing the protection considerably simpler and is not simply a level of indirection.
  • References: ASVS verification requirement V2.14

PI-0003: What is a "TOV" or "Target of Verification"?

  • Issue: New terminology
  • Resolution: If you are performing an application security verification according to ASVS, the verification will be of a particular application. This application is called the "Target of Verification" or simply the TOV. The TOV should be identified in verification documentation as follows:
    • TOV Identification – <name and version of the application> or <Application name>, <application version>, dynamic testing was performed in a staging environment, not the production environment
    • TOV Developer – <insert name of the developer or verification customer>
  • References: ASVS section "Approach"

Asvs-writing.JPG If you can help with translations, please download the latest draft here:

https://github.com/OWASP/ASVS

If there are any incomprehensible English idiom or phrases in there, please don't hesitate to ask for clarification, because if it's hard to translate, it's almost certainly wrong in English as well. We recommend logging translation issues in GitHub, too, so please make yourself known.

Translations are coordinated through OWASP's Crowd In account, so you don't have to do the entire thing yourself.

https://crowdin.com/project/owasp-asvs/

You don't HAVE to use Crowd In, but it would be nice to indicate to other native speakers of your language that you are willing to work together. This is a 70 page document, and in all honesty, will take a dedicated person a week or more to translate, so please please please work together rather than apart. You have full access to the original document and the original images, so you have everything I have.

*Please note that the current version of ASVS is v4.0. The information on this page is for archival purposes only.*

Application Security Verification Standard 3.0.1

ASVS 3.0.1 in English

ASVS 3.0.1 in Spanish

ASVS 3.0.1 in Polish

ASVS 3.0.1 in Persian

We are looking for translators for this version. If you can help us, please contact the project mail list!

Legacy Application Security Verification Standard 3.0

ASVS 3.0 in English

Older versions

Application Security Verification Standard 2.0 (final)

Application Security Verification Standard 1.0 - 2009

Asvs-step1.jpg'1. About ASVS 1.0'

Asvs-step2.jpg'2. Get ASVS 1.0'

  • ASVS in Bahasa Indonesia (Indonesian language) (PDF)
  • ASVS in Bahasa Malaysia (Malay) (Currently under development!)
  • ASVS in Chinese(Currently under development!)
  • ASVS in English (PDF, Word, Online, XML)
  • ASVS in French (PDF, OpenOffice)
  • ASVS in German (PDF, Word)
  • ASVS in Hungarian (Currently under development!)
  • ASVS in Japanese (PDF, Word)
  • ASVS in Persian (Farsi) (PDF) beta 0.7
  • ASVS in Polish (PDF)
  • ASVS in Portuguese-Brazil (PDF)
  • ASVS in Spanish (Currently under development!)
  • ASVS in Thai (Currently under development!)

Asvs-step3.jpg'3. Learn ASVS 1.0'

  • ASVS Article: Getting Started Using ASVS (PDF)
  • ASVS Article: Code Reviews and Other Verification Activities: USELESS Unless Acted Upon IMMEDIATELY (Wiki)
  • ASVS Article: Agile Software Development: Don't Forget EVIL User Stories (Wiki)
  • ASVS Article: Man vs. Code (Wiki)
  • ASVS Article: Getting started designing for a level of assurance (PDF)
  • ASVS Template: Sample verification fee schedule template (Excel)
  • ASVS Template: Sample verification report template (Word)
  • ASVS Training: An ASVS training presentation (PowerPoint)
  • ASVS Presentation: Executive-Level Presentation (PowerPoint)
  • ASVS Presentation: Presentation Abstract (Word)
  • Articles (More About ASVS and Using It)