File Protection Mechanisms
File Protection Mechanisms
File Protection Mechanisms
Until now, we have examined approaches to protecting a general object, no matter the object's nature
or type. But some protection schemes are particular to the type. To see how they work, we focus in this
section on file protection. The examples we present are only representative; they do not cover all
possible means of file protection on the market.
We noted earlier that all multiuser operating systems must provide some minimal protection to keep
one user from maliciously or inadvertently accessing or modifying the files of another. As the number of
users has grown, so also has the complexity of these protection schemes.
AllNone Protection
In the original IBM OS operating systems, files were by default public. Any user could read, modify, or
delete a file belonging to any other user. Instead of software- or hardware-based protection, the
principal protection involved trust combined with ignorance. System designers supposed that users
could be trusted not to read or modify others' files because the users would expect the same respect
from others. Ignorance helped this situation, because a user could access a file only by name;
presumably users knew the names only of those files to which they had legitimate access.
However, it was acknowledged that certain system files were sensitive and that the system
administrator could protect them with a password. A normal user could exercise this feature, but
passwords were viewed as most valuable for protecting operating system files. Two philosophies guided
password use. Sometimes, passwords controlled all accesses (read, write, or delete), giving the system
administrator complete control over all files. But at other times passwords controled only write and
delete accesses because only these two actions affected other users. In either case, the password
mechanism required a system operator's intervention each time access to the file began.
However, this all-or-none protection is unacceptable for several reasons.
Lack of trust. The assumption of trustworthy users is not necessarily justified. For systems with few
users who all know each other, mutual respect might suffice; but in large systems where not every user
knows every other user, there is no basis for trust.
Too coarse. Even if a user identifies a set of trustworthy users, there is no convenient way to allow
access only to them.
Rise of sharing. This protection scheme is more appropriate for a batch environment, in which users
have little chance to interact with other users and in which users do their thinking and exploring when
not interacting with the system. However, on shared-use systems, users interact with other users and
programs representing other classes of users.
Complexity. Because (human) operator intervention is required for this file protection, operating
system performance is degraded. For this reason, this type of file protection is discouraged by
computing centers for all but the most sensitive data sets.
File listings. For accounting purposes and to help users remember for what files they are responsible,
various system utilities can produce a list of all files. Thus, users are not necessarily ignorant of what files
reside on the system. Interactive users may try to browse through any unprotected files.
Group Protection
Because the all-or-nothing approach has so many drawbacks, researchers sought an improved way to
protect files. They focused on identifying groups of users who had some common relationship. In a
typical Unix+ implementation, the world is divided into three classes: the user, a trusted working group
associated with the user, and the rest of the users. For simplicity we can call these classes user, group,
and world. Windows NT+ uses groups such as Administrators, Power Users, Users, and Guests. (NT+
administrators can also create other groups.)
All authorized users are separated into groups. A group may consist of several members working on a
common project, a department, a class, or a single user. The basis for group membership is need to
share. The group members have some common interest and therefore are assumed to have files to
share with the other group members. In this approach, no user belongs to more than one group.
(Otherwise, a member belonging to groups A and B could pass along an A file to another B group
member.)
When creating a file, a user defines access rights to the file for the user, for other members of the same
group, and for all other users in general. Typically, the choices for access rights are a limited set, such as
{update, readexecute, read, writecreatedelete}. For a particular file, a user might declare read-only
access to the general world, read and update access to the group, and all rights to the user. This
approach would be suitable for a paper being developed by a group, whereby the different members of
the group might modify sections being written within the group. The paper itself should be available for
people outside the group to review but not change.
A key advantage of the group protection approach is its ease of implementation. A user is recognized by
two identifiers (usually numbers): a user ID and a group ID. These identifiers are stored in the file
directory entry for each file and are obtained by the operating system when a user logs in. Therefore,
the operating system can easily check whether a proposed access to a file is requested from someone
whose group ID matches the group ID for the file to be accessed.
Although this protection scheme overcomes some of the shortcomings of the all-or-nothing scheme, it
introduces some new difficulties of its own.
Group affiliation. A single user cannot belong to two groups. Suppose Tom belongs to one group with
Ann and to a second group with Bill. If Tom indicates that a file is to be readable by the group, to which
group(s) does this permission refer? Suppose a file of Ann's is readable by the group; does Bill have
access to it? These ambiguities are most simply resolved by declaring that every user belongs to exactly
one group. (This restriction does not mean that all users belong to the same group.)
Multiple personalities. To overcome the one-person one-group restriction, certain people might obtain
multiple accounts, permitting them, in effect, to be multiple users. This hole in the protection approach
leads to new problems because a single person can be only one user at a time. To see how problems
arise, suppose Tom obtains two accounts, thereby becoming Tom1 in a group with Ann and Tom2 in a
group with Bill. Tom1 is not in the same group as Tom2, so any files, programs, or aids developed under
the Tom1 account can be available to Tom2 only if they are available to the entire world. Multiple
personalities lead to a proliferation of accounts, redundant files, limited protection for files of general
interest, and inconvenience to users.
All groups. To avoid multiple personalities, the system administrator may decide that Tom should have
access to all his files any time he is active. This solution puts the responsibility on Tom to control with
whom he shares what things. For example, he may be in Group1 with Ann and Group2 with Bill. He
creates a Group1 file to share with Ann. But if he is active in Group2 the next time he is logged in, he still
sees the Group1 file and may not realize that it is not accessible to Bill, too.
Limited sharing. Files can be shared only within groups or with the world. Users want to be able to
identify sharing partners for a file on a per-file basis; for example, sharing one file with ten people and
another file with twenty others.
Individual Permissions
In spite of their drawbacks, the file protection schemes we have described are relatively simple and
straightforward. The simplicity of implementing them suggests other easy-to-manage methods that
provide finer degrees of security while associating permission with a single file.
Persistent Permission
From other contexts you are familiar with persistent permissions . The usual implementation of such a
scheme uses a name (you claim a dinner reservation under the name of Sanders), a token (you show
your driver's license or library card), or a secret (you say a secret word or give the club handshake).
Similarly, in computing you are allowed access by being on the access list, presenting a token or ticket,
or giving a password. User access permissions can be required for any access or only for modifications
(write access).
All these approaches present obvious difficulties in revocation: Taking someone off one list is easy, but it
is more complicated to find all lists authorizing someone and remove him or her. Reclaiming a token or
password is even more challenging.
This peculiar-sounding permission has a useful application. It permits a user to establish data files to
which access is allowed only through specified procedures.
For example, suppose you want to establish a computerized dating service that manipulates a database
of people available on particular nights. Sue might be interested in a date for Saturday, but she might
have already refused a request from Jeff, saying she had other plans. Sue instructs the service not to
reveal to Jeff that she is available. To use the service, Sue, Jeff, and others must be able to read the file
and write to it (at least indirectly) to determine who is available or to post their availability. But if Jeff
can read the file directly, he would find that Sue has lied. Therefore, your dating service must force Sue
and Jeff (and all others) to access this file only through an access program that would screen the data
Jeff obtains. But if the file access is limited to read and write by you as its owner, Sue and Jeff will never
be able to enter data into it.
The solution is the Unix SUID protection. You create the database file, giving only you access permission.
You also write the program that is to access the database, and save it with the SUID protection. Then,
when Jeff executes your program, he temporarily acquires your access permission, but only during
execution of the program. Jeff never has direct access to the file because your program will do the actual
file access. When Jeff exits from your program, he regains his own access rights and loses yours. Thus,
your program can access the file, but the program must display to Jeff only the data Jeff is allowed to
see.
This mechanism is convenient for system functions that general users should be able to perform only in
a prescribed way. For example, only the system should be able to modify the file of users' passwords,
but individual users should be able to change their own passwords any time they wish. With the SUID
feature, a password change program can be owned by the system, which will therefore have full access
to the system password table. The program to change passwords also has SUID protection so that when
a normal user executes it, the program can modify the password file in a carefully constrained way on
behalf of the user.
The primary limitation of these protection schemes is the ability to create meaningful groups of related
users who should have similar access to related objects. The access control lists or access control
matrices described earlier provide very flexible protection. Their disadvantage is for the user who wants
to allow access to many users and to many different data sets; such a user must still specify each data
set to be accessed by each user. As a new user is added, that user's special access rights must be
specified by all appropriate users.
User Authentication
An operating system bases much of its protection on knowing who a user of the system is. In real-life
situations, people commonly ask for identification from people they do not know: A bank employee may
ask for a driver's license before cashing a check, library employees may require some identification
before charging out books, and immigration officials ask for passports as proof of identity. In-person
identification is usually easier than remote identification. For instance, some universities do not report
grades over the telephone because the office workers do not necessarily know the students calling.
However, a professor who recognizes the voice of a certain student can release that student's grades.
Over time, organizations and systems have developed means of authentication, using documents, voice
recognition, fingerprint and retina matching, and other trusted means of identification.
In computing, the choices are more limited and the possibilities less secure. Anyone can attempt to log
in to a computing system. Unlike the professor who recognizes a student's voice, the computer cannot
recognize electrical signals from one person as being any different from those of anyone else. Thus,
most computing authentication systems must be based on some knowledge shared only by the
computing system and the user.
Something the user knows. Passwords, PIN numbers, passphrases, a secret handshake, and
mother's maiden name are examples of what a user may know.
Something the user has. Identity badges, physical keys, a driver's license, or a uniform are
common examples of things people have that make them recognizable.
Something the user is. These authenticators, called biometrics, are based on a physical
characteristic of the user, such as a fingerprint, the pattern of a person's voice, or a face (picture). These
authentication methods are old (we recognize friends in person by their faces or on a telephone by their
voices) but are just starting to be used in computer authentications. See Sidebar 4-3 for a glimpse at
some of the promising approaches.
Two or more forms can be combined for more solid authentication; for example, a bank card and a PIN
combine something the user has with something the user knows.
Passwords as Authenticators
The most common authentication mechanism for user to operating system is a password, a "word"
known to computer and user. Although password protection seems to offer a relatively secure system,
human practice sometimes degrades its quality. In this section we consider passwords, criteria for
selecting them, and ways of using them for authentication. We conclude by noting other authentication
techniques and by studying problems in the authentication process, notably Trojan horses
masquerading as the computer authentication process.
Use of Passwords
Passwords are mutually agreed-upon code words, assumed to be known only to the user and the
system. In some cases a user chooses passwords; in other cases the system assigns them. The length and
format of the password also vary from one system to another.
Even though they are widely used, passwords suffer from some difficulties of use:
Loss. Depending on how the passwords are implemented, it is possible that no one will be able to
replace a lost or forgotten password. The operators or system administrators can certainly intervene
and unprotect or assign a particular password, but often they cannot determine what password a user
has chosen; if the user loses the password, a new one must be assigned.
Use. Supplying a password for each access to a file can be inconvenient and time consuming.
Revocation. To revoke one user's access right to a file, someone must change the password, thereby
causing the same problems as disclosure.
The use of passwords is fairly straightforward. A user enters some piece of identification, such as a name
or an assigned user ID; this identification can be available to the public or easy to guess because it does
not provide the real security of the system. The system then requests a password from the user. If the
password matches that on file for the user, the user is authenticated and allowed access to the system.
If the password match fails, the system requests the password again, in case the user mistyped.
Additional Authentication Information
In addition to the name and password, we can use other information available to authenticate users.
Suppose Adams works in the accounting department during the shift between 8:00 a.m. and 5:00 p.m.,
Monday through Friday. Any legitimate access attempt by Adams should be made during those times,
through a workstation in the accounting department offices. By limiting Adams to logging in under those
conditions, the system protects against two problems:
Someone from outside might try to impersonate Adams. This attempt would be thwarted by either the
time of access or the port through which the access was attempted.
Adams might attempt to access the system from home or on a weekend, planning to use resources not
allowed or to do something that would be too risky with other people around.
Limiting users to certain workstations or certain times of access can cause complications (as when a user
legitimately needs to work overtime, a person has to access the system while out of town on a business
trip, or a particular workstation fails). However, some companies use these authentication techniques
because the added security they provide outweighs inconveniences.
How secure are passwords themselves? Passwords are somewhat limited as protection devices because
of the relatively small number of bits of information they contain.
Here are some ways you might be able to determine a user's password, in decreasing order of difficulty.
Loose-Lipped Systems
So far the process seems secure, but in fact it has some vulnerabilities. To see why, consider the actions
of a would-be intruder. Authentication is based on knowing the <name, password> pair A complete
outsider is presumed to know nothing of the system. Suppose the intruder attempts to access a system
in the following manner. (In the following examples, the system messages are in uppercase, and the
user's responses are in lowercase.)
We assumed that the intruder knew nothing of the system, but without having to do much, the intruder
found out that adams is not the name of an authorized user. The intruder could try other common
names, first names, and likely generic names such as system or operator to build a list of authorized
users.
INVALID ACCESS
ENTER USER NAME:
This system notifies a user of a failure only after accepting both the user name and the password. The
failure message should not indicate whether it is the user name or password that is unacceptable. In this
way, the intruder does not know which failed.
These examples also gave a clue as to which computing system is being accessed. The true outsider has
no right to know that, and legitimate insiders already know what system they have accessed. In the
example below, the user is given no information until the system is assured of the identity of the user.
Exhaustive Attack
But the break-in time can be made more tractable in a number of ways. Searching for a single particular
password does not necessarily require all passwords to be tried; an intruder needs to try only until the
correct password is identified. If the set of all possible passwords were evenly distributed, an intruder
would likely need to try only half of the password space: the expected number of searches to find any
particular password. However, an intruder can also use to advantage the fact that passwords are not
evenly distributed. Because a password has to be remembered, people tend to pick simple passwords.
This feature reduces the size of the password space.
Probable Passwords
Think of a word.
Is the word you thought of long? Is it uncommon? Is it hard to spell or to pronounce? The answer to all
three of these questions is probably no.
Penetrators searching for passwords realize these very human characteristics and use them to their
advantage. Therefore, penetrators try techniques that are likely to lead to rapid success. If people prefer
short passwords to long ones, the penetrator will plan to try all passwords
but to try them in order by length. There are only 261 + 262 + 26 3=18,278 passwords of length 3 or less.
At the assumed rate of one password per millisecond, all of these passwords can be checked in 18.278
seconds, hardly a challenge with a computer. Even expanding the tries to 4 or 5 characters raises the
count only to 475 seconds (about 8 minutes) or 12,356 seconds (about 3.5 hours), respectively.
This analysis assumes that people choose passwords such as vxlag and msms as often as they pick enter
and beer. However, people tend to choose names or words they can remember. Many computing
systems have spelling checkers that can be used to check for spelling errors and typographic mistakes in
documents. These spelling checkers sometimes carry online dictionaries of the most common English
words. One contains a dictionary of 80,000 words. Trying all of these words as passwords takes only 80
seconds.
If Sandy is selecting a password, she is probably not choosing a word completely at random. Most likely
Sandy's password is something meaningful to her. People typically choose personal passwords, such as
the name of a spouse, a child, a brother or sister, a pet, a street name, or something memorable or
familiar. If we restrict our password attempts to just names of people (first names), streets, projects,
and so forth, we generate a list of only a few hundred possibilities at most. Trying this number of
passwords takes under a second! Even a person working by hand could try ten likely candidates in a
minute or two.
Thus, what seemed formidable in theory is in fact quite vulnerable in practice, and the likelihood of
successful penetration is frightening. Morris and Thompson [MOR79] confirmed our fears in their report
on the results of having gathered passwords from many users, shown in Table 4-2. Figure 4-15 (based on
data from that study) shows the characteristics of the 3,289 passwords gathered. The results from
that study are distressing, and the situation today is likely to be the same. Of those passwords, 86
percent could be uncovered in about one week's worth of 24-hour-a-day testing, using the very
generous estimate of 1 millisecond per password check.
Lest you dismiss these results as dated (they were reported in 1979), Klein repeated the experiment in
1990 [KLE90] and Spafford in 1992 [SPA92]. Each collected approximately 15,000 passwords. Klein
reported that 2.7 percent of the passwords were guessed in only 15 minutes of machine time and 21
percent were guessed within a week! Spafford found the average password length was 6.8 characters,
and 28.9 percent consisted of only lowercase alphabetic characters. Notice that both these studies were
done after the Internet worm (described in Chapter 3) succeeded, in part by breaking weak passwords.
Even in 2002, the British online bank Egg found users still choosing weak passwords [BUX02]. A full 50
percent of passwords for their online banking service were family members' names: 23 percent
children's names, 19 percent a spouse or partner, and 9 percent their own. Alas, pets came in at only 8
percent, while celebrities and football (soccer) stars tied at 9 percent each. And in 1998, Knight and
Hartley [KNI98] reported that approximately 35 percent of passwords are deduced from syllables and
initials of the account owner's name.
Two friends we know have told us their passwords as we helped them administer their systems, and
their passwords would both have been among the first we would have guessed. But, you say, these are
amateurs unaware of the security risk of a weak password. At a recent meeting, a security expert related
this experience: He thought he had chosen a solid password, so he invited a class of students to ask him
a few questions and offer some guesses as to his password. He was amazed that they asked only a few
questions before they had deduced the password. And this was a security expert.
Several news articles have claimed that the four most common passwords are "God," "sex," "love,"and
"money" (the order among those is unspecified). The perhaps apocryphal list of common passwords
at geodsoft.com/howto/password/common.htm appears at several other places on the Internet. Or see
the default password list at www.phenoelit.de/dpl/dpl.html. Whether these are really passwords we do
not know. Still, it warrants a look because similar lists are bound to be built into some hackers' tools.
Several network sites post dictionaries of phrases, science fiction characters, places, mythological
names, Chinese words, Yiddish words, and other specialized lists. All these lists are posted to help site
administrators identify users who have chosen weak passwords, but the same dictionaries can also be
used by attackers of sites that do not have such attentive administrators. The COPS [FAR90],
Crack [MUF92], and SATAN [FAR95] utilities allow an administrator to scan a system for weak
passwords. But these same utilities, or other homemade ones, allow attackers to do the same. Now
Internet sites offer so-called password recovery software as freeware or shareware for under $20.
(These are password-cracking programs.)
People think they can be clever by picking a simple password and replacing certain characters, such as 0
(zero) for letter O, 1 (one) for letter I or L, 3 (three) for letter E or @ (at) for letter A. But users aren't the
only people who could think up these substitutions. Knight and Hartley [KNI98] list, in order, 12 steps an
attacker might try in order to determine a password. These steps are in increasing degree of difficulty
(number of guesses), so they indicate the amount of work to which the attacker must go to derive a
password. Here are their password guessing steps:
· no password
· the same as the user ID
· common word list (for example, "password," "secret," "private") plus common names and patterns
(for example, "asdfg," "aaaaaa")
· short college dictionary with capitalizations (PaSsWorD) and substitutions (0 for O, and so forth)
Although the last step will always succeed, the steps immediately preceding it are so time consuming
that they will deter all but the dedicated attacker for whom time is not a limiting factor.
To validate passwords, the system must have a way of comparing entries with actual passwords. Rather
than trying to guess a user's password, an attacker may instead target the system password file. Why
guess when with one table you can determine all passwords with total accuracy?
On some systems, the password list is a file, organized essentially as a two-column table of user IDs and
corresponding passwords. This information is certainly too obvious to leave out in the open. Various
security approaches are used to conceal this table from those who should not see it.
You might protect the table with strong access controls, limiting access to the operating system. But
even this tightening of control is looser than it should be, because not every operating system module
needs or deserves access to this table. For example, the operating system scheduler, accounting
routines, or storage manager have no need to know the table's contents. Unfortunately, in some
systems, there are n+1 known users: n regular users and the operating system. The operating system is
not partitioned, so all its modules have access to all privileged information. This monolithic view of the
operating system implies that a user who exploits a flaw in one section of the operating system has
access to all the system's deepest secrets. A better approach is to limit table access to the modules that
need access: the user authentication module and the parts associated with installing new users, for
example.
If the table is stored in plain sight, an intruder can simply dump memory at a convenient time to access
it. Careful timing may enable a user to dump the contents of all of memory and, by exhaustive search,
find values that look like the password table.
System backups can also be used to obtain the password table. To be able to recover from system
errors, system administrators periodically back up the file space onto some auxiliary medium for safe
storage. In the unlikely event of a problem, the file system can be reloaded from a backup, with a loss
only of changes made since the last backup. Backups often contain only file contents, with no protection
mechanism to control file access. (Physical security and access controls to the backups themselves are
depended on to provide security for the contents of backup media.) If a regular user can access the
backups, even ones from several weeks, months, or years ago, the password tables stored in them may
contain entries that are still valid.
Finally, the password file is a copy of a file stored on disk. Anyone with access to the disk or anyone who
can overcome file access restrictions can obtain the password file.
There is an easy way to foil an intruder seeking passwords in plain sight: encrypt them. Frequently, the
password list is hidden from view with conventional encryption or one-way ciphers.
With conventional encryption, either the entire password table is encrypted or just the password
column. When a user's password is received, the stored password is decrypted, and the two are
compared.
Even with encryption, there is still a slight exposure because for an instant the user's password is
available in plaintext in main memory. That is, the password is available to anyone who could obtain
access to all of memory.
A safer approach uses one-way encryption, defined in Chapter 2. The password table's entries are
encrypted by a one-way encryption and then stored. When the user enters a password, it is also
encrypted and then compared with the table. If the two values are equal, the authentication succeeds.
Of course, the encryption has to be such that it is unlikely that two passwords would encrypt to the
same ciphertext, but this characteristic is true for most secure encryption algorithms.
With one-way encryption, the password file can be stored in plain view. For example, the password
table for the Unix operating system can be read by any user unless special access controls have been
installed. Because the contents are encrypted, backup copies of the password table are no longer a
problem.
There is always the possibility that two people might choose the same password, thus creating two
identical entries in the password file. Even though the entries are encrypted, each user will know the
plaintext equivalent. For instance, if Bill and Kathy both choose their passwords on April 1, they might
choose APRILFOOL as a password. Bill might read the password file and notice that the encrypted
version of his password is the same as Kathy's.
Unix+ circumvents this vulnerability by using a password extension, called the salt. The salt is a 12-bit
number formed from the system time and the process identifier. Thus, the salt is likely to be unique for
each user, and it can be stored in plaintext in the password file. The salt is concatenated to Bill's
password (pw) when he chooses it; E(pw+saltB) is stored for Bill, and his salt value is also stored. When
Kathy
chooses her password, the salt is different because the time or the process number is different. Call this
new one saltK. For her, E (pw+saltK) and saltK are stored. When either person tries to log in, the system
fetches the appropriate salt from the password table and
combines that with the password before performing the encryption. The encrypted versions of (pw+salt)
are very different for these two users. When Bill looks down the password list, the encrypted version of
his password will not look at all like Kathy's.
Storing the password file in a disguised form relieves much of the pressure to secure it. Better still is to
limit access to processes that legitimately need access. In this way, the password file is protected to a
level commensurate with the protection provided by the password itself. Someone who has broken the
controls of the file system has access to data, not just passwords, and that is a serious threat. But if an
attacker successfully penetrates the outer security layer, the attacker still must get past the encryption
of the password file to access the useful information in it.
Indiscreet Users
Guessing passwords and breaking encryption can be tedious or daunting. But there is a simple way to
obtain a password: Get it directly from the user! People often tape a password to the side of a terminal
or write it on a card just inside the top desk drawer. Users are afraid they will forget their passwords, or
they cannot be bothered trying to remember them. It is particularly tempting to write the passwords
down when users have several accounts.
Users sharing work or data may also be tempted to share passwords. If someone needs a file, it is easier
to say "my password is x; get the file yourself" than to arrange to share the file. This situation is a result
of user laziness, but it may be brought about or exacerbated by a system that makes sharing
inconvenient.
In an admittedly unscientific poll done by Verisign [TEC05], two-thirds of people approached on the
street volunteered to disclose their password for a coupon good for a cup of coffee, and 79 percent
admitted they used the same password for more than one system or web site.
Password Selection Criteria
At the RSA Security Conference in 2006, Bill Gates, head of Microsoft, described his vision of a world in
which passwords would be obsolete, having gone the way of the dinosaur. In their place sophisticated
multifactor authentication technologies would offer far greater security than passwords ever could. But
that is Bill Gates' view of the future; despite decades of articles about their weakness, passwords are
with us still and will be for some time.
So what can we conclude about passwords? They should be hard to guess and difficult to determine
exhaustively. But the degree of difficulty should be appropriate to the security needs of the situation. To
these ends, we present several guidelines for password selection:
Use characters other than just AZ. If passwords are chosen from the letters AZ, there are only 26
possibilities for each character. Adding digits expands the number of possibilities to 36. Using both
uppercase and lowercase letters plus digits expands the number of possible characters to 62. Although
this change seems small, the effect is large when someone is testing a full space of all possible
combinations of characters. It takes about 100 hours to test all 6-letter words chosen from letters of one
case only, but it takes about 2 years to test all 6-symbol passwords from upper- and lowercase letters
and digits. Although 100 hours is reasonable, 2 years is oppressive enough to make this attack far less
attractive.
Choose long passwords. The combinatorial explosion of passwords begins at length 4 or 5. Choosing
longer passwords makes it less likely that a password will be uncovered. Remember that a brute force
penetration can stop as soon as the password is found. Some penetrators will try the easy casesknown
words and short passwordsand move on to another target if those attacks fail.
Avoid actual names or words. Theoretically, there are 266 or about 300 million 6-letter "words", but
there are only about 150,000 words in a good collegiate dictionary, ignoring length. By picking one of
the 99.95 percent nonwords, you force the attacker to use a longer brute force search instead of the
abbreviated dictionary search.
Choose an unlikely password. Password choice is a double bind. To remember the password easily, you
want one that has special meaning to you. However, you don't want someone else to be able to guess
this special meaning. One easy-to-remember password is 2Brn2B. That unlikely looking jumble is a
simple transformation of "to be or not to be." The first letters of words from a song, a few letters from
different words of a private phrase, or a memorable basketball score are examples of reasonable
passwords. But don't be too obvious. Password-cracking tools also test replacements of 0 (zero) for o or
O (letter "oh") and 1 (one) for l (letter "ell") or $ for S (letter "ess"). So I10veu is already in the search file.
Change the password regularly. Even if there is no reason to suspect that the password has been
compromised, change is advised. A penetrator may break a password system by obtaining an old list or
working exhaustively on an encrypted list.
Don't write it down. (Note: This time-honored advice is relevant only if physical security is a serious
risk. People who have accounts on many different machines and servers, not to mention bank and
charge card PINs, may have trouble remembering all the access codes. Setting all codes the same or
using insecure but easy-to-remember passwords may be more risky than writing passwords on a
reasonably well protected list.)
Don't tell anyone else. The easiest attack is social engineering, in which the attacker contacts the
system's administrator or a user to elicit the password in some way. For example, the attacker may
phone a user, claim to be "system administration," and ask the user to verify the user's password. Under
no circumstances should you ever give out your private password; legitimate administrators can
circumvent your password if need be, and others are merely trying to deceive you.
To help users select good passwords, some systems provide meaningless but pronounceable passwords.
For example, the VAX VMS system randomly generates five passwords from which the user chooses one.
They are pronounceable, so that the user should be able to repeat and memorize them. However, the
user may misremember a password because of having interchanged syllables or letters of a meaningless
string. (The sound "bliptab" is no more easily misremembered than "blaptib" or "blabtip.")
Yan et al. [YAN04] did experiments to determine whether users could remember passwords or
passphrases better. First, they found that users are poor at remembering random passwords. And
instructions to users about the importance of selecting good passwords had little effect. But when they
asked users to select their own password based on some mnemonic phrase they chose themselves, the
users selected passwords that were harder to guess than regular (not based on a phrase) passwords.
Other systems encourage users to change their passwords regularly. The regularity of password change
is usually a system parameter, which can be changed for the characteristics of a given installation.
Suppose the frequency is set at 30 days. Some systems begin to warn the user after 25 days that the
password is about to expire. Others wait until 30 days and inform the user that the password has
expired. Some systems nag without end, whereas other systems cut off a user's access if a password has
expired. Still others force the user immediately into the password change utility on the first login after
30 days.
Grampp and Morris [GRA84a] argue that this reminder process is not necessarily good. Choosing
passwords is not difficult, but under pressure a user may adopt any password, just to satisfy the system's
demand for a new one. Furthermore, if this is the only time a password can be changed, a bad password
choice cannot be changed until the next scheduled time.
Sometimes when systems force users to change passwords periodically, users with favorite passwords
will alternate between two passwords each time a change is required. To prevent password reuse,
Microsoft Windows 2000 systems refuse to accept any of the k most recently used passwords. One user
of such a system went through 24 password changes each month, just to cycle back to the favorite
password.
One-Time Passwords
A one-time password is one that changes every time it is used. Instead of assigning a static phrase to a
user, the system assigns a static mathematical function. The system provides an argument to the
function, and the user computes and returns the function value. Such systems are also
called challengeresponse systems because the system presents a challenge to the user and judges the
authenticity of the user by the user's response. Here are some simple examples of one-time password
functions; these functions are overly simplified to make the explanation easier. Very complex functions
can be used in place of these simple ones for host authentication in a network.
f(x) = x + 1. With this function, the system prompts with a value for x, and the user enters the value x +
1. The kinds of mathematical functions used are limited only by the ability of the user to compute the
response quickly and easily. Other similar possibilities are f(x) = 3x2 - 9x + 2, f(x) = px, where px is the xth
prime number, or f(x) = d * h, where d is the date and h is the hour of the current time. (Alas, many
users cannot perform simple arithmetic in their heads.)
f(x) = r(x). For this function, the receiver uses the argument as the seed for a random number generator
(available to both the receiver and host). The user replies with the value of the first random number
generated. A variant of this scheme uses x as a number of random numbers to generate. The receiver
generates x random numbers and sends the xth of these to the host.
f(a1a2a3a4a5a6) = a3a1a1a4. With this function, the system provides a character string, which the user must
transform in some predetermined manner. Again, many different character operations can be used.
f(E(x)) = E(D(E(x)) + 1). In this function, the computer sends an encrypted value, E(x). The user must
decrypt the value, perform some mathematical function, and encrypt the result to return it to the
system. Clearly, for human use, the encryption function must be something that can be done easily by
hand, unlike the strong encryption algorithms in Chapter 2. For machine-to-machine authentication,
however, an encryption algorithm such as DES or AES is appropriate.
One-time passwords are very important for authentication because (as becomes clear in Chapter 7 ) an
intercepted password is useless because it cannot be reused. However, their usefulness is limited by the
complexity of algorithms people can be expected to remember. A password-generating device can
implement more complex functions. Several models are readily available at reasonable prices. They are
very effective at countering the threat of transmitting passwords in plaintext across a network.
(See Sidebar 4-4 for another dilemma in remote authentication.)
The Authentication Process
Authentication usually operates as described previously. However, users occasionally mistype their
passwords. A user who receives a message of INCORRECT LOGIN will carefully retype the login and gain
access to the system. Even a user who is a terrible typist should be able to log in successfully in a few
tries.
Some authentication procedures are intentionally slow. A legitimate user will not complain if the login
process takes 5 or 10 seconds. To a penetrator who is trying an exhaustive search or a dictionary search,
however, 5 or 10 seconds per trial makes this class of attack generally infeasible.
Someone whose login attempts continually fail may not be an authorized user. Systems commonly
disconnect a user after a small number of failed logins, forcing the user to reestablish a connection with
the system. (This action will slow down a penetrator who is trying to penetrate the system by telephone.
After a small number of failures, the penetrator must reconnect, which takes a few seconds.)
In more secure installations, stopping penetrators is more important than tolerating users' mistakes. For
example, some system administrators assume that all legitimate users can type their passwords
correctly within three tries. After three successive password failures, the account for that user is
disabled and only the security administrator can reenable it. This action identifies accounts that may be
the target of attacks by penetrators.
Password authentication assumes that anyone who knows a password is the user to whom the
password belongs. As we have seen, passwords can be guessed, deduced, or inferred. Some people give
out their passwords for the asking. Other passwords have been obtained just by someone watching a
user typing in the password. The password can be considered as a preliminary or first-level piece of
evidence, but skeptics will want more convincing proof.
There are several ways to provide a second level of protection, including another round of passwords or
a challengeresponse interchange.
ChallengeResponse Systems
As we have just seen, the login is usually time invariant. Except when passwords are changed, each login
looks like every other. A more sophisticated login requires a user ID and password, followed by a
challengeresponse interchange. In such an interchange, the system prompts the user for a reply that will
be different each time the user logs in. For example, the system might display a four-digit number, and
the user would have to correctly enter a function such as the sum or product of the digits. Each user is
assigned a different challenge function to compute. Because there are many possible challenge
functions, a penetrator who captures the user ID and password cannot necessarily infer the proper
function.
A physical device similar to a calculator can be used to implement a more complicated response
function. The user enters the challenge number, and the device computes and displays the response for
the user to type in order to log in. (For more examples, see Chapter 7's discussion of network
authentication.)
Impersonation of Login
In the systems we have described, the proof is one-sided. The system demands certain identification of
the user, but the user is supposed to trust the system. However, a programmer can easily write a
program that displays the standard prompts for user ID and password, captures the pair entered, stores
the pair in a file, displays SYSTEM ERROR; DISCONNECTED, and exits. This attack is a type of Trojan
horse.
The perpetrator sets it up, leaves the terminal unattended, and waits for an innocent victim to attempt a
login. The naïve victim may not even suspect that a security breach has occurred.
To foil this type of attack, the user should be sure the path to the system is reinitialized each time the
system is used. On some systems, turning the terminal off and on again or pressing the BREAK key
generates a clear signal to the computer to halt any running process for the terminal. (Microsoft chose
<CTRLALTDELETE> as the path to the secure authorization mechanism for this reason.) Not every
computer recognizes power-off or BREAK as an interruption of the current process, though. And
computing systems are often accessed through networks, so physical reinitialization is impossible.
Alternatively, the user can be suspicious of the computing system, just as the system is suspicious of the
user. The user will not enter confidential data (such as a password) until convinced that the computing
system is legitimate. Of course, the computer acknowledges the user only after passing the
authentication process. A computing system can display some information known only by the user and
the system. For example, the system might read the user's name and reply "YOUR LAST LOGIN WAS 10
APRIL AT 09:47." The user can verify that the date and time are correct before entering a secret
password. If higher security is desired, the system can send an encrypted timestamp. The user decrypts
this and discovers that the time is current. The user then replies with an encrypted timestamp and
password, to convince the system that a malicious intruder has not intercepted a password from some
prior login.