The 25 most dangerous programming errors
Connecting state and local government leaders
The Common Weakness Enumeration project, co-sponsored by DHS, identifies the most common coding mistakes in a list of more than 800 weaknesses.
The most serious common error in programming today leaves software open to SQL injection, which allows attackers to bypass security and gain access to internal data, and which was used in recent attacks by the LulzSec group to breach high-profile targets such as the CIA and an FBI Infragard chapter, according to the latest ranking of the coding errors.
A coalition of government, academic and private sector security organizations on June 27 released an updated version of the list of the top 25 coding errors considered to be responsible for the majority of security vulnerabilities plaguing software.
The Top 25 list is a product of the Common Weakness Enumeration (CWE) project, managed by Mitre Corp. and the SANS Institute, and co-sponsored by the Homeland Security Department’s National Cyber Security Division, to develop a common way for identifying and expressing software programming errors.
Related coverage:
Fresh advice on building safer software
This year’s list of the Top 25 most serious errors was created with the help of a scoring system and risk analysis framework being developed by the project to prioritize more than 800 common programming weaknesses that have been identified by the program.
The Common Weakness Enumeration originally was released in 2008 with 734 entries; 136 new entries have since been added to the most recent release. The Top 25 list is an effort to prioritize the errors that represent the greatest risks.
“Based primarily on the CWE List and leveraging the SANS Top 20 attack vectors, the main goal of the Top 25 list is to stop vulnerabilities at the source by educating programmers on how to eliminate all-too-common mistakes before software is even shipped,” Mitre said in releasing the new list. “Software consumers may also use the list to help them to ask for more secure software, and software managers and CIOs can use the Top 25 as a measuring stick of progress in their efforts to secure their software.”
Top weaknesses are identified in three high-level categories: Insecure interaction between components, risky resource management and porous defenses. The No. 1 error in this year’s list, “improper neutralization of special elements used in an SQL command,” or SQL injection, is included in the insecure interactions category.
SQL injection long has been a recognized problem and moved up one spot from its No. 2 position in last year’s list. The top problem in last year’s list, cross-site scripting, dropped to No. 4 this year.
Eight new errors made their way into this year’s top 25. The highest ranked error from last year’s list to be pushed out of this year’s was improper access controls that allow improper authorization of users, which was number five last year and does not appear this year.
Preliminary versions of the Common Weakness Scoring System (CWSS) and the Common Weakness Risk Evaluation Framework (CWRAF) have been released for comment.
“CWSS 0.8 is a significant revision over the previous versions with a better formula, and improvements in the values and weights for individual factors,” MITRE said.
“CWRAF provides a way for organizations to apply the Common Weakness Scoring System using specialized scenarios (‘vignettes’) that identify the business value context of deployed applications in order to prioritize those software weaknesses in CWE that are most relevant to their own businesses, missions, and deployed technologies,” Mitre said. “In conjunction with other activities, CWRAF ultimately helps software developers and consumers to introduce more secure software into their operational environments.”
Comments on CWSS and CWRAF can be sent to cwss@mitre.org.
The Top 25 list on Mitre’s site includes links to explanations of each error. The list by name:
- Improper neutralization of special elements used in an SQL command (“SQL injection”).
- Improper neutralization of special elements used in an OS command (“OS command injection”).
- Buffer copy without checking size of input (“classic buffer overflow”).
- Improper neutralization of input during Web page generation (“cross-site scripting”).
- Missing authentication for critical function.
- Missing authorization.
- Using hard-coded credentials.
- Missing encryption of sensitive data.
- Unrestricted upload of file with dangerous type.
- Reliance on untrusted inputs in a security decision.
- Execution with unnecessary privileges.
- Cross-site request forgery.
- Improper limitation of a pathname to a restricted directory (“path traversal”).
- Download of code without integrity check.
- Incorrect authorization.
- Inclusion of functionality from untrusted control sphere.
- Incorrect permission assignment for critical resource.
- Using a potentially dangerous function.
- Using a broken or risky cryptographic algorithm.
- Incorrect calculation of buffer size.
- Improper restriction of excessive authentication attempts.
- URL redirection to untrusted site (“open redirect”).
- Uncontrolled format string.
- Integer overflow or wraparound.
- Using a one-way hash without a salt.