Vulnerability (computing)

Vulnerability (computing)

In computer security, the term vulnerability is applied to a weakness in a system which allows an attacker to violate the integrity of that system. Vulnerabilities may result from weak passwords, software bugs, a computer virus or other malware, a script code injection, or a SQL injection.

A security risk is classified as a vulnerability if it is recognized as a possible means of attack. A security risk with one or more known instances of working and fully-implemented attacks is classified as an exploit.

Constructs in programming languages that are difficult to use properly can be a large source of vulnerabilities.

Causes

*Password Management Flaws The computer user uses weak passwords that could be discovered by brute force. The computer user stores the password on the computer where a program can access it. Users re-use passwords between many programs and websites.

*Fundamental Operating System Design Flaws – The operating system designer chooses to enforce sub optimal policies on user/program management. For example operating systems with policies such as default permit grant every program and every user full access to the entire computer. This operating system flaw allows viruses and malware to execute commands on behalf of the administrator. [http://www.ranum.com/security/computer_security/editorials/dumb/]

*Software Bugs – The programmer leaves an exploitable bug in a software program. The software bug may allow an attacker to misuse an application through (for example) bypassing access control checks or executing commands on the system hosting the application. Also the programmer's failure to check the size of data buffers, which can then be overflowed, causing corruption of the stack or heap areas of memory (including causing the computer to execute code provided by the attacker).

*Unchecked User Input – The program assumes that all user input is safe. Programs that do not check user input can allow unintended direct execution of commands or SQL statements (known as Buffer overflows, SQL injection or other non-validated inputs).

Vulnerability disclosure

The method of disclosing vulnerabilities is a topic of debate in the computer security community. Some advocate immediate full disclosure of information about vulnerabilities once they are discovered. Others argue for limiting disclosure to the users placed at greatest risk, and only releasing full details after a delay, if ever. Such delays may allow those notified to fix the problem by developing and applying patches, but may also increase the risk to those not privy to full details. This debate has a long history in security; see full disclosure and security through obscurity. More recently a new form of commercial vulnerability disclosure has taken shape, as some commercial security companies offer money for exclusive disclosures of Zero Day vulnerabilities. Those offers provide a legitimate market for the purchase and sale of vulnerability information from the security community.

From the security perspective, a free and public disclosure is only successful if the affected parties get the relevant information prior to potential hackers, if they did not the hackers could take immediate advantage of the revealed exploit. With Security Through Obscurity the same rule applies, but this time rests on the hackers finding the vulnerability themselves, as opposed to being given the information from another source. The disadvantage here is that there is a lower number of people with full knowledge of the vulnerability who can aid in finding similar or related scenarios.

It should be unbiased to enable a fair dissemination of security critical information. Most often a channel is considered trusted when it is a widely accepted source of security information in the industry (e.g CERT, SecurityFocus, Secunia and [http://www.frsirt.com/english FrSIRT] ).Analysis and risk rating ensure the quality of the disclosed information. The analysis must include enough details to allow a concerned user of the software to assess his individual risk or take immediate action to protect his assets.

Vulnerability disclosure date

The time of disclosure of a vulnerability is defined differently in the security community and industry. It is most commonly referred to as "a kind of public disclosure of security information by a certain party". Usually, vulnerability information is discussed on a mailing list or published on a security web site and results in a security advisory afterwards.

The time of disclosure is the first date a security vulnerability is described on a channel where the disclosed information on the vulnerability has to fulfil the following requirement:

*the information is freely available to the public
*the vulnerability information is published by a trusted and independent channel/source
*the vulnerability has undergone analysis by experts such that risk rating information is included upon disclosure

Identifying and removing vulnerabilities

Many software tools exist that can aid in the discovery (and sometimes removal) of vulnerabilities in a computer system. Though these tools can provide an auditor with a good overview of possible vulnerabilities present, they can not replace human judgment. Relying solely on scanners will yield false positives and a limited-scope view of the problems present in the system.

Vulnerabilities have been found in every major operating system including Windows, Mac OS, various forms of Unix and Linux, OpenVMS, and others. The only way to reduce the chance of a vulnerability being used against a system is through constant vigilance, including careful system maintenance (e.g. applying software patches), best practices in deployment (e.g. the use of firewalls and access controls) and auditing (both during development and throughout the deployment lifecycle).

Examples of vulnerabilities

Common types of vulnerabilities include:
*Memory safety violations, such as:
**Buffer overflows
**Dangling pointers
*Input validation errors, such as:
**Format string bugs
**Improperly handling shell metacharacters so they are interpreted
**SQL injection
**Code injection
**E-mail injection
**Directory traversal
**Cross-site scripting in web applications
*Race conditions, such as:
**Time-of-check-to-time-of-use bugs
**Symlink races
*Privilege-confusion bugs, such as:
**Cross-site request forgery in web applications
*Privilege escalation
*User interface failures, such as:
**Warning fatigue [http://www.freedom-to-tinker.com/?p=459] or user conditioning [http://www.cs.auckland.ac.nz/~pgut001/pubs/phishing.pdf]
**Blaming the Victim Prompting a user to make a security decision without giving the user enough information to answer it [http://blog.mozilla.com/rob-sayre/2007/09/28/blaming-the-victim/]
**Race Conditions [http://www.squarefree.com/2004/07/01/race-conditions-in-security-dialogs/]

ee also

* Exploit (computer science)
* Computer security
* Computer insecurity
* Common Vulnerabilities and Exposures (CVE)
* Common Vulnerability Scoring System (CVSS)
* Y2K

External links

* [http://www.aitcnet.org/isai/ Languages Standard's group] : Guidance for Avoiding Vulnerabilities through Language Selection and Use
* [http://www.microsoft.com/technet/archive/community/columns/security/essays/vulnrbl.mspx Microsoft Security Response Center] : Definition of a Security Vulnerability
* [http://support.microsoft.com/kb/946480 List of fixes that are included in Windows XP Service Pack 3]
* [http://samate.nist.gov/ NIST Software Assurance Metrics and Tool Evaluation (SAMATE) project]
* [http://www.osvdb.org/ Open Source Vulnerability Database (OSVDB) homepage]
* [http://www.owasp.org/index.php/Category:Vulnerability Open Web Application Security Project]
* [http://secwatch.org/ SecWatch Vulnerability Archive]
* [http://www.frsirt.com/english French Security Incident Response Team (FrSIRT) Vulnerability Archive]
* [http://secunia.com/ Secunia Vulnerability Archive]
* [http://www.securityfocus.com/bid SecurityFocus Vulnerability Archive]
* [http://www.milw0rm.com/ milw0rm Vulnerability and Exploit Archive]
* [http://www.cve.mitre.org/ Common Vulnerabilities and Exposures (CVE)]
* [http://www-935.ibm.com/services/us/index.wss/offerfamily/iss/a1029112 IBM Internet Security Systems (ISS) X-Force research and development team]
* [http://www.itwire.com/content/view/19954/53/ ITWIRE] : Apple tops vulnerability list, but Microsoft still ahead on exploits August 11, 2008


Wikimedia Foundation. 2010.

Игры ⚽ Поможем сделать НИР

Look at other dictionaries:

  • Vulnerability — For other uses of the word Vulnerability , please refer to vulnerability (computing) You may also want to refer to natural disaster. Vulnerability is the susceptibility to physical or emotional injury or attack. It also means to have one s guard… …   Wikipedia

  • vulnerability — noun ADJECTIVE ▪ extreme, great ▪ critical ▪ potential ▪ known, well known ▪ economic …   Collocations dictionary

  • Windows Metafile vulnerability — The Windows Metafile vulnerability is a security vulnerability in Microsoft Windows NT based operating systems which has been used in a variety of exploits since late December 2005. The vulnerability was first discussed in the computer security… …   Wikipedia

  • Patch (computing) — Software update redirects here. For the software tool by Apple Inc., see Apple Software Update. For the Unix program, see patch (Unix). For the file format, see diff. A patch is a piece of software designed to fix problems[1] with, or update a… …   Wikipedia

  • Trustworthy Computing — The term Trustworthy Computing (TwC) has been applied to computing systems that are inherently secure, available and reliable. The Committee on Information Systems Trustworthiness’ publication, Trust in Cyberspace, defines such a system as one… …   Wikipedia

  • Cloud computing security — (sometimes referred to simply as cloud security ) is an evolving sub domain of computer security, network security, and, more broadly, information security. It refers to a broad set of policies, technologies, and controls deployed to protect data …   Wikipedia

  • Security Operation Center (computing) — A Security Operation Center (SOC) is an organization that delivers IT security services. It attempts to prevent unauthorized access and manage security related incidents using processes and procedures. The mission is risk management through… …   Wikipedia

  • Defense in depth (computing) — Defense in depth is an information assurance (IA) concept in which multiple layers of security controls (defense) are placed throughout an information technology (IT) system. Its intent is to provide redundancy in the event a security control… …   Wikipedia

  • Malware — Malware, short for malicious software, consists of programming (code, scripts, active content, and other software) designed to disrupt or deny operation, gather information that leads to loss of privacy or exploitation, gain unauthorized access… …   Wikipedia

  • Hacker (computer security) — This article is part of a series on …   Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”