Directories | Web | Images | Groups | News | Shopping | Local

Enter your search keyword(s):

 



(formerly Encyclopedic directory)
Ethics
Home / Top / Computers / Hacking / Ethics

(formerly Encyclopedic directory)

See also:
Related articles

Edit | Discuss Article

Hacker

Hacker is a term used to describe different types of computer experts. It is also sometimes extended to mean any kind of expert, especially with the connotation of having particularly detailed knowledge or of cleverly circumventing limits.
"Hacker" is used in two main ways, one positive and and one pejorative.  It can be used in the computing community to describe a particularly brilliant programmer or technical expert (for example: "Linus Torvalds, the creator of Linux, is a genius hacker.").  This is said by some to be the "correct" usage of the word (see the Jargon File definition below).  In popular usage and in the media, however, it generally describes computer intruders or criminals.  "Hacker" can be seen as a shibboleth, identifying those who use it in its positive sense as members of the computing community.

As a result of this conflict, the term is the subject of some controversy. The pejorative usage is disliked by many who identify themselves as hackers, and who do not like their label used negatively. Many users of the positive form say the "intruder" meaning should be deprecated, and advocate terms such as "cracker" or "black-hat" to replace it. Others prefer to follow common popular usage, arguing that the positive form is confusing and never likely to become widespread.

Table of contents
1 History
2 Categories of hacker
3 Jargon File definition
4 Summary of terms
5 Notable hackers
6 See also
7 External links
8 Other meanings of the word "hacker"

History

Here is a timeline of the noun "hack" and etymologically related terms as they evolved in historical English:

  • In Old French, haquenée meant an ambling horse.
  • In Old English, tohaccian meant hack to pieces.
  • At some point in the 14th century, the word haquenée became hackney, meaning a horse of medium size or fair quality.
  • Shortly after,hackney was shortened to hack, and in riding culture the act of "hacking" (as opposed to fox-hunting) meant riding about informally, to no particular purpose.
  • 1393 (at the latest): the word had also acquired the meaning of a horse for hire and also "prostitute".
  • 1596: hackney was being used as an adjective meaning tired or worn out. Shakespeare also used the word to mean "to make common and overly familiar" in Henry IV, Part I.
  • 1700: a hack is a "person hired to do routine work".
  • 1704: hack now also means a "carriage for hire".
  • 1749: hack means "one who writes anything for hire" (still in use today among writers)
  • 1802: hack is used to mean a "short, dry cough" (still in use)
  • 1826: the expression "a hack writer" is first recorded though hackney writer appeared at least 50 years earlier
  • 1898: hack is given the figurative sense of "a try, an attempt".
  • 1950s: ham radio fans borrowed the term hacking from riding and defined it as creatively tinkering to improve performance.
  • 1955: American English gives it the slang sense of "cope with" (as in "can't hack it"). On the U.S. East Coast, cars were substituted for horses, and hacking was a precursor to cruising.

The modern, computer-related form of the term is likely rooted in the goings on at MIT in the 60's long before computers became common; a "hack" meant a simple, but often inelegant, solution. The term hack came to refer to any clever prank perpetrated by MIT students; logically the perpetrator is a hacker. To this day the terms hack and hacker are used in that way at MIT, without necessarily referring to computers. When MIT students surreptitiously put a police car atop the dome on MIT's Building 10, that was a hack, and the students involved were therefore hackers. This type of hacker is now sometimes called a Reality Hacker or Urban spelunker.

In the nascent computer culture of the 1960s, the unavoidable analogy to "hacking" programs was the already-established counter-culture practice of chopping Harley-Davidsons in Southern California: taking them apart and "chopping" their frames, improvising to make them lower, sleeker, faster, hotter than their uncustomized "stock" originals.

The term was fused with computers when members of the Tech Model Railroad Club started working with a Digital Equipment Corporation PDP-1 computer and applied local model railroad slang to computers.

The earliest known use of the term in this manner is from the 20 November 1963 issue of The Tech, the student paper of the Massachusetts Institute of Technology:

"Many telephone services have been curtailed because of so-called hackers, according to Prof. Carlton Tucker, administrator of the Institute phone system. [...] The hackers have accomplished such things as tying up all the tie-lines between Harvard and MIT, or making long-distance calls by charging them to a local radar installation. One method involved connecting the PDP-1 computer to the phone system to search the lines until a dial tone, indicating an outside line, was found. [...] Because of the "hacking," the majority of the MIT phones are "trapped.""

Originally, the term applied almost exclusively to programming or electrical engineering, but it has come to be used in some circles for almost any type of clever circumvention, in phrases such as "hack the media", "hack your brain" and "hack your reputation".

Categories of hacker

The hacker community (the set of people who would describe themselves as hackers, or who would be described by others as hackers) falls into at least three partially overlapping categories.

Hacker: Brilliant programmer

The positive usage of hacker. One who knows a (sometimes specified) set of programming interfaces well enough to write software rapidly and expertly. This type of hacker is well-respected, although the term still carries some of the meaning of hack, developing programs without adequate planning. This zugzwang gives freedom and the ability to be creative against methodical careful progress.

At their best, hackers can be very productive. The downside of hacker productivity is often in maintainability, documentation, and completion. Very talented hackers may become bored with a project once they have figured out all of the hard parts, and be unwilling to finish off the "details". This attitude can cause friction in environments where other programmers are expected to pick up the half finished work, decipher the structures and ideas, and bullet-proof the code. In other cases, where a hacker is willing to maintain their own code, a company may be unable to find anyone else who is capable or willing to dig through code to maintain the program if the original programmer moves on to a new job.

Types of hackers in this sense are gurus and wizards. "Guru" implies age and experience, and "wizard" often implies particular expertise in a specific topic, and an almost magical ability to perform hacks no one else understands.

Hacker: Intruder and criminal

The most common usage of "hacker" in the popular press is to describe those who subvert computer security without authorization. This can mean taking control of a remote computer through a network, or software cracking. This is the pejorative sense of hacker, also called cracker or black-hat hacker.

There are several recurring tools of the trade used by hackers to gain unauthorized access to computers:

  • Trojan horse -- These are applications that seem to do useful work, but set up a back door so that the hacker can later return and enter the system. These include programs which mimic login screens. Viruses that fool a user into downloading and/or executing them by pretending to be useful applications are also sometimes called trojan horses.
  • Virus -- An application that propagates itself opportunistically by waiting in the background until the user offers it a new medium to infect. The term came into usage by comparison with biological viruses, which reproduce by infecting a cell and taking advantage of its life functions. Similarly, computer viruses embed themselves within files on the host system. When "infected" executables run, or sometimes when infected binary data files are read, the virus is able to spread to other binary format files on the local system, floppy disks or over the network.
  • Worm -- An application that actively probes for known weaknesses on other computers across the network, then propagates itself through an exploitation of those weaknesses. The original Usenet post describing the Morris Worm described the distinction between viruses and worms thus: worms do not attach themselves to code. Popular usage appears to describe worms as being more active than viruses. However, the Jargon File, as of version 4.4.1, maintains the original sense of the term. A worm in this original sense is any independent program which reproduces itself over a network (a program reproducing itself on the local machine only repeatedly until the machine crashes is known as a wabbit). After the comparison between computer viruses and biological viruses, the obvious comparison here is to a bacterium.
(Note that many people conflate the terms "virus" and "worm", using them both to describe any self-propagating program. In practice the distinction may be difficult to make, as certain programs exhibit both virus and worm-like properties. However, when a distinction is made, it is as described above.)
  • Vulnerability scanner -- A tool used to quickly check computers on a network for known weaknesses. Hackers also use port scanners. These check to see which ports on a specified computer are "open" or available to access the computer. (Note that firewalls defend computers from hackers by closing off all unnecessary ports.)
  • Sniffer -- An application that captures password and other data while it is in transit either within the computer or over the network
  • Exploit -- A prepared application that takes advantage of a known weakness.
  • Social engineering -- Asking someone for the password or account (possibly over a beer.) Also includes looking over someone's shoulder while they enter their password, or posing as someone else in order to get sensitive information.
  • Root kit -- A toolkit for hiding the fact that a computer's security has been compromised. Root kits may include replacements for system binaries so that it becomes impossible for the legitimate user to detect the presence of the intruder on the system by looking at process tables.
  • Leet -- An English pidgin that helps to obscure hacker discussions and web sites, and paradoxically it simplifies the location of resources in public search engines for those who know the language. This is arguably more of a social phenomenon than anything very useful for breaking security, however. To more effectively keep conversations private, encryption can be used.

An incompetent black-hat hacker who is unable to write his own tools is known as a script kiddie. The term expresses contempt, being meant to indicate that he is immature and only uses other people's "scriptss".

Hacker: Security expert

There is a third meaning which is a kind of fusion of the positive and pejorative senses of hacker. The term white hat hacker is often used to describe those who attempt to break into systems or networks in order to help the owners of the system by making them aware of security flaws, or to perform some other altruistic activity. Many such people are employed by computer security companies (such professionals are sometimes called sneakers).

White hat hackers often overlap with black hat depending on your perspective. The primary difference is that a white hat hacker claims to observe the hacker ethic. Like black hats, white hats are often intimately familiar with the internal details of security systems, and can delve into obscure machine code when needed to find a solution to a tricky problem without requiring support from a system manufacturer.

An example of a hack: Microsoft Windows ships with the ability to use cryptographic libraries built into the operating system. When shipped overseas this feature becomes nearly useless as the operating system will refuse to load cryptographic libraries that haven't been signed by Microsoft, and Microsoft will not sign a library unless the US Government authorizes it for export. This allows the US Government to maintain some perceived level of control over the use of strong cryptography beyond its borders.

While hunting through the symbol table of a beta release of Windows, a couple of overseas hackers managed to find a second signing key in the Microsoft binaries. That is without disabling the libraries that are included with Windows (even overseas) these individuals learned of a way to trick the operating system into loading a library that hadn't been signed by Microsoft, thus enabling the functionality which had been lost to non-US users.

Whether this is good or bad may depend on whether you respect the letter of the law, but is considered by some in the computing community to be a white hat type of activity. Some use the term grey hat to describe someone on the borderline between black and white.

Jargon File definition

The following is the definition given by the most recent edition of the Jargon File (a dictionary of hacker jargon), which emphasizes the positive sense of "hacker". The definitions in this dictionary were not made through research into common usage, but reflect to some extent the opinions of its editors. Hence, the following is accepted by some but not all of the hacker community.
hacker n.

[originally, someone who makes furniture with an axe]

  1. A person who enjoys exploring the details of programmable systems and how to stretch their capabilities, as opposed to most users, who prefer to learn only the minimum necessary.
  2. One who programs enthusiastically (even obsessively) or who enjoys programming rather than just theorizing about programming.
  3. A person capable of appreciating hack value.
  4. A person who is good at programming quickly.
  5. An expert at a particular program, or one who frequently does work using it or on it; as in `a Unix hacker'. (Definitions 1 through 5 are correlated, and people who fit them congregate.)
  6. An expert or enthusiast of any kind. One might be an astronomy hacker, for example.
  7. One who enjoys the intellectual challenge of creatively overcoming or circumventing limitations.
  8. [deprecated] A malicious meddler who tries to discover sensitive information by poking around. Hence `password hacker', `network hacker'. The correct term for this sense is cracker.

The term `hacker' also tends to connote membership in the global community defined by the net (see the network and Internet address). For discussion of some of the basics of this culture, see the How To Become A Hacker FAQ. It also implies that the person described is seen to subscribe to some version of the hacker ethic.

It is better to be described as a hacker by others than to describe oneself that way. Hackers consider themselves something of an elite (a meritocracy based on ability), though one to which new members are gladly welcome. There is thus a certain ego satisfaction to be had in identifying yourself as a hacker (but if you claim to be one and are not, you'll quickly be labeled bogus). See also geek, wannabe.

This term seems to have been first adopted as a badge in the 1960s by the hacker culture surrounding TMRC and the MIT AI Lab. We have a report that it was used in a sense close to this entry's by teenage radio hams and electronics tinkerers in the mid-1950s.

The earliest Stanford revisions of the Jargon file (1975) did not describe the term so positively, including only definitions 4, 5 and 8. The current definition was written in more or less its current form around 1980 at MIT. Definition 8 was "deprecated" in the 1990s by Jargon File editor Eric S. Raymond, a known advocate of the positive usage of "hacker".

Summary of terms

Guru, Wizard: Types of hacker in the positive sense.

Cracker, Black-hat: A hacker in the negative sense.

Script kiddie: A hacker, in the negative sense, with little or no skill. A script kiddie simply follows directions or uses a cook-book approach without fully understanding the meaning of the steps they are performing.

White-hat, Sneaker, Grey-hat: A hacker who breaks security but who does so for altruistic or at least non-malicious reasons. The darker the hat, the more the ethics of the activity can be considered dubious.

Note also that even among users of the positive sense of "hacker", the noun hack usually means kludge and thus nearly always has a negative connotation. Meanwhile, the verb hack can share the same positive connotations.

Notable hackers

Brilliant programmers

Intruders and criminals

Note that many of these have since turned to fully legal hacking.

Webmasters: Add your website here:

Readers: Edit | Discuss Listings

Old and New Hacker Ethics
Is there a Hacker Ethic for 90s Hackers?
http://www.fiu.edu/~mizrachs/hackethic.html

Hacker Ethics
Richard Stallmans Interview.
http://mbhs.bergtraum.k12.ny.us/cybereng/ebooks/stallman.htm

Computer Ethics and Hacking
A report about computer ethics, viruses, hacking and software copyrights in Arabic
http://www.geocities.com/lool95

Hacker Culture
Steve Mizrach of the dept. of Anthropology, University of Florida, summarizes his findings in a new set of ethical principles.
http://webzone.k3.mah.se/k3jolo/HackerCultures/newethics.htm

The Hacker Crackdown
Electronic edition.
http://www.mit.edu/hacker/hacker.html

EFFweb - The Electronic Frontier Foundation
Seek to protect the rights of computer users in criminal proceedings.
http://www.eff.org/

Conscience of a Hacker
A hacker's manifesto.
http://www.geocities.com/carail666/

Computer Hacking and Ethics
Paper about developing ethics in teenage hackers.
http://www.cs.berkeley.edu/~bh/hackers.html



Help build the largest human-edited directory on the web.
 Submit a Site - Open Directory Project (modified) - Become an Editor

Modified contents copyright 2008. All rights reserved.