Internet Fundamental Notes
Internet Fundamental Notes
Class Work: 50
.
NOTE: For setting up the question paper, question no 1 will be set up from all the four
sections which will be compulsory and of short answer type. Two questions will be set from
each of the four sections. The students have to attempt first common question, which is
compulsory, and one question from each of the four sections. Thus students will have to
attempt 5 questions out of 9 questions.
Section C: Languages:
Basic and advanced HTML, java script language, Client and Server Side Programming in java
script. Forms and data in java script, XML basics. Introduction to Web Servers: PWS, IIS,
Apache; Microsoft Personal Web Server. Accessing & using these servers.
Text Book:
□ Fundamentals of the Internet and the World Wide Web, Raymond Greenlaw and Ellen
Hepp – 2001, TMH
□ Internet & World Wide Programming, Deitel,Deitel & Nieto, 2000, Pearson Education
Reference Books:
□ Complete idiots guide to java script,. Aron Weiss, QUE, 1997
□ Network firewalls, Kironjeet syan -New Rider Pub.
□ www.secinf.com
□ www.hackers.com
□ Alfred Glkossbrenner-Internet 101 Computing MGH, 1996
Email
      Electronic mail (also known as email or e-mail) is one of the most commonly used services
on the Internet, allowing people to send messages to one or more recipients. Email was invented
by Ray Tomlinson in 1972.
      It is a system used for creating, sending and storing textual data in digital form over a
network. Earlier, the e-mail system was based on Simple Mail Transfer Protocol (SMTP)
mechanism, a protocol used for sending e-mails from one server to another. Today's e-mail
technology uses the store-and-forward model. In this model, the user sends and receives
information on their own computer terminal. However, the computer is used only for connecting
to the e-mail architecture. The creation, transmission and storage of e-mail takes place, only
when the connection with this e-mail architecture is established.
      E-mail is one of the many technological developments that have influenced our lives. It has
changed the medium of communication. So, it becomes necessary for us to have a look at the
benefits and harmful effects of this popular mailing tool.
Email Facilities
       All email systems have the ability to send, receive and discard mail. Most systems have
facilities for storing mail which is to be kept rather than discarded. It is important to discard mail
which does not need to be kept, as it uses storage space on disks. Mailboxes can soon accumulate
a large number of mail messages making it difficult to read and process new mail, in addition to
wasting disk space.
       There is almost always a connection between the email system and the computer's standard
file system which allows mail to be read from files or written to files. This enables greater
flexibility in how the mail system is used. For example, a mail message may be prepared in a
normal file using a familiar text editor and then sent by the email system. Sections of other files
may be included in the mail message as well.
       Most systems have a reply facility, although some of these do not always work as expected.
Care should be taken when using this facility in electronic mail, as replies do not always go back
to the sender.
Advantages of Email
The benefits of e-mail are huge in number.
Easy to use: E-mail frees us from the tedious task of managing data for daily use. It helps us
manage our contacts, send mails quickly, maintain our mail history, store the required
information, etc.
Speed: An e-mail is delivered instantly and anywhere across the globe. No other service matches
the e-mail in terms of speed.
Easy to prioritize: Because e-mails come with a subject line, it is easy to prioritize them and
ignore the unwanted ones.
Reliable and secure: Constant efforts are being taken to improve the security in electronic
mails. It makes e-mail one of the secured ways of communication.
Informal and conversational: The language used in e-mails is generally simple and thus, makes
the process of communication informal. Sending and receiving e-mails takes less time, so it can
be used as a tool for interaction.
Easier for reference: When a person needs to reply to a mail, he/she can use the provision of
attaching previous mails as references. It helps refresh the recipient's know-how on what he is
reading.
Automated e-mails: It is possible to send automated e-mails using special programs
like autoresponders. The autoresponders reply only to those messages with generalized, pre-
written text messages.
Environment friendly: Postal mails use paper as a medium to send letters. Electronic mail
therefore, prevents a large number of trees from getting axed. It also saves the fuel needed for
transportation.
Use of graphics: Colorful greeting cards and interesting pictures can be sent through e-mails.
This adds value to the e-mail service.
Advertising tool: Nowadays, many individuals and companies are using the e-mail service to
advertise their products, services, etc.
  Info at your fingertips: Storing data online means less large, space taking file cabinets, folders
  and shelves. You can access information far quicker if you learn how to use email this way.
  Leverage: Send the same message to any number of people. Adaptations are simple, too. If you
  have a product or service to sell, email is an effective medium to get your message out.
  Send reminders to yourself. Do you use more than one account? Email yourself messages from
  work to home or vice versa.
Disadvantages of Email
The e-mail service, though beneficial in our day-to-day life, has got its own drawbacks that are
off late coming to the fore.
Viruses: These are computer programs which have the potential to harm a computer system.
These programs copy themselves and further infect the computer. The recipient needs to scan the
mails since; viruses are transmitted through them and have the potential to harm computer
systems.
Spam: E-mails when used to send unsolicited messages and unwanted advertisements create
nuisance and are termed as Spam. Checking and deleting these unwanted mails can unnecessarily
consume a lot of time. It has therefore, become necessary to block or filter unwanted e-mails by
means of spam filters. Spamming is practiced by sending hoax e-mails. E-mail spoofing is
another common practice, used for spamming. The act of spoofing involves deceiving the
recipient by altering e-mail headers or addresses from which the mail is sent.
Hacking: The act of breaking into computer security is termed as hacking. In this form of
security breach, e-mails are intercepted by hackers. An e-mail before being delivered to the
recipient, "bounces" between servers located in different parts of the world; hence, it can be
hacked by a professional hacker.
Misinterpretation: One has to be careful while posting content through an e-mail. If typed in a
hurry, the matter could be misinterpreted.
Lengthy mails: If the mail is too long and not properly presented, the reader may lose interest in
reading it.
Not suitable for business: Since the content posted via e-mails is considered informal, there is a
chance of business documents going unnoticed. Thus, urgent transactions and especially those
requiring signatures are not managed through e-mails.
Crowded inbox: Over a period of time, the e-mail inbox may get crowded with mails. It
becomes difficult for users to manage such a huge chunk of mails.
Need to check the inbox regularly: In order to stay updated, one has to check his e-mail
account regularly.
Lacks the personal touch: Some things are best left untyped. Email will never beat a hand
written card or letter when it comes to relationships.
      Every new technology enters the social world with its share of benefits and drawbacks.
Different people interpret and utilize it in different ways. In order to make the most of the
available technology, users should try to understand both, the positive and negative sides of the
tool they use. No technology can be deemed totally perfect!
Using email
     An email client, a software program for writing, checking and sending email, is generally
made up of a number of windows. The main windows of this software are:
• Incoming, In, Inbox: This represents the main mailbox for receiving email,
• Sent, Outbox, Out: These are copies of messages that you have sent.
• Deleted, Trash: The trash bin containing deleted emails. When emails are shown in the
   trash, you can still retrieve them. To permanently delete them, you will need empty the trash
   bin.
• Folders: Most clients can be used to file emails in folders, much like folders on a hard drive.
Email fields
Here are the meanings of the fields to be filled in when you send an email:
•   From: this is your email address; most of the time you will not have to fill in this field,
    because it is generally set by the email client according to your preferences.
•   To: This field is used for the recipient's email address.
•   Subject: this is the title that your recipients will see when they want to read the email
•   Cc (carbon copy): this allows an email to be send to a large number of people by writing their
    respective addresses separated by commas
•   Bcc (blind carbon copy): This is a Cc, except that the recipient does not see the list of people
    in the Bcc field
•   Message: This is the body of your message
      The Carbon Copy function sends a copy to people not directly involved with the message
but whom you wish to keep up to date with the message contents or show that you sent the email
to the recipient(s).
      The Blind Carbon Copy function makes it possible to forward messages without any of the
recipients or even the hidden recipients seeing that the message is being forwarded to them. It is
generally recommended when sending an email to many people to forward it using Blind copy so
as to prevent one of the recipients from replying to everyone or assembling a list of addresses.
Userid
The userid identifies you to the computer. Userids are typically some form of your name. (Your
last name, for example). A userid must be unique throughout the computer system. This allows
the computer to distinguish between you and some other person. One confusing issue is that
different systems refer to a userid (the thing that identifies you to the computer) with different
names. Some that you may run across are:
Login ID
Username
Userid
But, they all refer to that special name that identifies you to that particular computer system.
      Your userid is also used for communication with other people through electronic mail.
Since the userid identifies you to the computer, it is natural for it to be used to identify you to
other computer systems. For example: The person Joe B. User could have this userid, "jbu3470".
The userid is made up of the person's initials and the digits of some personal identification
number.
Password
      To prevent other people from using your account via your userid, you are required to have
a password. A password allows you and only you to access the computer system through your
userid. It basically proves to the computer system that you are who you say you are. So it should
be obvious that you DO NOT GIVE YOUR PASSWORD TO ANYONE!!!
User ID:
User IDs must be 7-14 characters
User IDs must contain at least one letter; numbers are allowed, but not required
User IDs cannot contain spaces
User IDs cannot contain your Social Security Number, Tax Identification Number, or Customer
Access Number
No special characters are allowed, such as: ! @ # $ % ^ &
Use of an underscore is allowed but not required: _
Do not use your Password as your User ID
Password:
Passwords must be 7-14 characters
Passwords must include at least one letter and one number
Passwords cannot contain spaces
Semicolons cannot be part of a Password
Passwords are case-sensitive
Do not use your User ID as your Password
If you forget your User ID or Password, you can retrieve them through the "User ID & Password
Help" link.
Email addresses
      Electronic mail must be addressed properly, in much the same way as a normal letter needs
to be addressed, in order that it can reach its intended recipient. However, with electronic mail
the addressing has to be slightly different and must be more precise than a conventional mail
address.
      Most email uses is addressed using internet addresses. These are supported by what is
known as the Domain Name Server (DNS). This is an internationally distributed naming scheme
and the components of each address are structured in a hierarchical manner. These start with the
mailname of the person, followed by various address components, ending with the "Top level"
domain (often a country code). In this respect, the addressing is in the same order as that of a
conventional letter.
      Email addresses (both for senders and recipients) are two strings separated by the character
"@" (the "at sign"): user@domain
      The right-hand part describes the domain name involved, and the left-hand part refers to the
user who belongs to that domain. One or more mail servers correspond to each domain.
An email address can be up to 255 characters long and can include the following characters:
•       Lowercase letters from a to z;
•       Digits
•       The characters ".","_" and "-" (full stop, underscore, and hyphen)
In practice, an email address often looks something like this:
[email protected]
For            example
[email protected]
      The mailname comes first, indicating who the email is for. The "@" sign separates the
mailname from the site. The next components indicate details of the system to which the email is
sent.
bham = Birmingham
ac = academic
uk = Great Britain
      The final component ("top level" domain) is normally the ISO3166 standard two letter
country code. There are, however, two main types of exception. One is Great Britain (gb) which
uses "uk". The other exceptions are mainly some of American domains (eg edu, mil, gov). These
are at the same "level" in the naming scheme as countries.
      Addresses of this form are also known as rfc822 addresses, because that is the name of the
Internet standard in which the addresses were originally described.
Message Components
 Header
       The header of an e-mail address is where all the important addressing information is kept,
 along with data about the message itself. The following table describes the elements that make
 up the header of an e-mail.
To        The TO Field is where the email address of the messages recipient is entered.
Subject The subject is essentially a title, or a very short summary, of an e-mail. Ideally it
        should contain some sort of reference to the emails content
CC        To Carbon Copy (CC) a message to someone is to send them a copy of the e-mail,
          even though they are not the e-mail’s intended recipient. This is a common practice in
          business communications, where many people in an organization often need to be
          made aware of certain communications, even if they are not actively involved in the
          conversation.
BCC       BCC stands for Blind Carbon Copy. Any people included in the BCC recipient list
          of an e-mail receive a copy of the message, but their name is not included in the
          message headers, and no one else who received the message knows that they were sent
          a copy.
Body
      The body of the message is, of course, the most important part. Everything you need to say
is entered here, and this is what the recipient will be reading.
Message Composition
Steps are:
     Launching your e-mail program is usually as simple as clicking on the e-mail icon on
        your desktop. Once the program is open, write a message by clicking on the Compose
        Mail, New Message or similar button.
      In the new message window, type the e-mail addresses of the recipients in the To field,
       or use the Address book to select one or more of the addresses.
      In the CC field, enter the address of anyone you want to receive a copy of the message.
       Type the e-mail address or choose it from the address book.
      Type the subject of the message.
      Now type your message.
      Finally, click on the Send button.
Mailer Features
      Most mailers provide common features which provide functionality for manipulating your
mail box contents, composing messages and saving messages to the disk. The features are:
E-mail Management
       Email is now the de facto standard for business communication across organizations at this
time. Recent research shows the extensive use of emails in business and its projected growth in
the future presents major information management challenges and risks for many organizations.
Just as any type of business information and record, email must be included as part of, and
adhered to the organizational standards addressing information and records:
     Capture
     Classification
     Storage
     Preservation
     Management
     Destruction
       The vast quantities of emails held in inboxes, sent folders, and deleted item folders put the
organization at risk and adversely impact the performance of email servers in the organizations.
Email servers were never designed to act as repositories for such great quantities of emails and
move control of this information away from the organization. Without the management of
emails, it is difficult for organizations to meet their legal preservation requirements in the event
of litigation and government investigations, increasing the effort and cost in responding to e-
discovery and disclosure.
       Email management systems centrally capture emails created and received by employees.
Using a classification scheme to manage this content, retention periods and access controls can
be applied to manage emails. Metadata associated with the emails can be captured to allow this
information to be managed and retrieved. Email active archiving is one of the most common
applications for email management. At their most basic, these solutions either copy or remove
messages from the messaging application and some it at another location. Some approaches copy
all messages coming into and out of the messaging application in real time, while others will
physically remove the messages from the message store. In some of these solutions, the
messages are not archived, but attachments are and are replaced with either a stub or an outright
link within the message.
       These email management systems, while attractive and effective, are merely part of an
overall solution. Organizations need to have records management programs, consisting of
organization-wide policies and procedures, staff and activities, in which these computer
applications can be successfully utilized.
Here are four simple email management rules to help you keep control of your inbox:
 Let your email program manage your email as much as possible.
     Email management starts with setting up and using filters. If you're using an email program
     such as Outlook, you can configure email rules to send your spam directly to the trash -
     meaning that you don't waste your time reading and deleting it.
  Do not check your email on demand.
     You don't need to see every piece of email the second it arrives. If you're using an email
     program that announces the arrival of new email, turn off the program's announcement
     features, such as making a sound or having a pop-up screen announce the arrival of email.
     Checking email on demand can seriously interfere with whatever other tasks you're trying to
     accomplish because most people will read email when they check it.
  Don't read and answer your email all day long.
     You may get anywhere from a handful to hundreds of emails each day that need to be
     answered, but they don't need to be answered immediately, interrupting whatever else you're
     doing. Instead, set aside a particular time each day to review and answer your email.
     Schedule the hour or whatever time it takes you to answer the volume of email you get, and
     stick to that schedule as regularly as possible.
  Don't answer your email at your most productive time of day.
     For me, (and for many others, I suspect), my most productive work time is the morning. If I
     start my work day by answering my email, I lose the time that I'm at my most creative. If I'm
     writing a piece, for instance, it takes me twice as long to compose it in the afternoon or
     evening than it would in the morning, when I feel fresh and alert.
       Answering email, on the other hand, isn't usually a task that calls for a great deal of
 creativity. So by ignoring my email until the late afternoon, and answering it then, I get the dual
 benefit of saving my most productive time for other more demanding tasks, and not continually
 interrupting whatever other tasks I'm trying to accomplish.
News Groups
      A newsgroup is a continuous public discussion about a particular topic. You can join a
newsgroup at any time to become part of a huge conversation between hundreds or even
thousands of people
      A newsgroup is a discussion about a particular subject consisting of notes written to a
central Internet site and redistributed through Usenet, a worldwide network of news discussion
groups. Usenet uses the Network News Transfer Protocol (NNTP).
      Newsgroups are organized into subject hierarchies, with the first few letters of the
newsgroup name indicating the major subject category and sub-categories represented by a
subtopic name. Many subjects have multiple levels of subtopics. Newsgroups are divided into
categories. The categories help to determine what kind of group and what kind of postings you
will find there. Some major subject categories are:
     news,
     rec (recreation),
     soc (society),
     sci (science),
     comp (computers), and so forth (there are many more).
     Alt
     talk
Use of Newsgroups We can use newsgroups for various purposes, for example:
    Newsgroups are an excellent way to find out web sites to visit in your particular area of
       interest or just pick up detailed information about area of interest.
    You can buy and sell stuff. People often advertise things for sale in some newsgroup.
      Users can post to existing newsgroups, respond to previous posts, and create new
newsgroups.
      Newcomers to newsgroups are requested to learn basic Usenet netiquette and to get
familiar with a newsgroup before posting to it. A frequently-asked questions is provided. The
rules can be found when you start to enter the Usenet through your browser or an online service.
You can subscribe to the postings on a particular newsgroup.
      Some newsgroups are moderated by a designated person who decides which postings to
allow or to remove. Most newsgroups are unmoderated.
Mailing Lists
     A mailing list is a collection of names and addresses used by an individual or an
organization to send material to multiple recipients. The term is often extended to include the
people subscribed to such a list, so the group of subscribers is referred to as "the mailing list", or
simply "the list".
Chat Rooms
      A chat room is a Web site, part of a Web site, or part of an online service such as America
Online, that provides a venue for communities of users with a common interest to communicate
in real time. Forums and discussion groups, in comparison, allow users to post messages but
don't have the capacity for interactive messaging. Most chat rooms don't require users to have
any special software; those that do, such as Internet Relay Chat (IRC) allow users to download it
from the Internet.
      Chat room users register for the chat room of their choice, choose a user name and
password, and log into a particular room (most sites have multiple chat rooms). Inside the chat
room, generally there is a list of the people currently online, who also are alerted that another
person has entered the chat room. To chat, users type a message into a text box. The message is
almost immediately visible in the larger communal message area and other users respond. Users
can enter chat rooms and read messages without sending any, a practice known as lurking.
      Because chat room messages are spontaneous and instantly visible, there is a potential for
abuse, which may or may not be intentional. Site hosts typically post a frequently asked
questions (FAQ) list to guide users to appropriate chat room behavior, such as introducing
yourself when you enter a room, making it clear when you are directing a question or response to
a specific user, and reporting disruptive users, for example. Disruptive users may verbally abuse
other chatters, monopolize the conversation, or even just disable it by repeatedly typing the same
word or phrase into the conversation, a practice (much frowned upon) known as scrolling.
      Chat rooms can be found that focus on virtually any aspect of human endeavor or interest:
there are current communities based on classic movies, Irish ancestry, baton twirling, and
psychic readings, for example. Various sites, such as Yahoo, provide a directory of chat sites.
Others, such as MSN Web Communities, guide users through the steps required to create their
own chat room.
Internetwork
      An internetwork is the connection of two or more private computer networks via a common
routing technology (OSI Layer 3) using routers. The Internet is an aggregation of many
internetworks; hence its name was shortened to Internet.
Backbone network
      A Backbone network (BBN) or network backbone is part of a computer network
infrastructure that interconnects various pieces of network, providing a path for the exchange of
information between different LANs or sub networks. A backbone can tie together diverse
networks in the same building, in different buildings in a campus environment, or over wide
areas. Normally, the backbone's capacity is greater than the networks connected to it.
Internet
      The Internet is a global system of interconnected governmental, academic, corporate,
public, and private computer networks. It is based on the networking technologies of the Internet
Protocol Suite.
      The Internet is a worldwide collection of computer networks, cooperating with each other
to exchange data using a common software standard. Through telephone wires and satellite links,
Internet users can share information in a variety of forms. The size, scope and design of the
Internet allow users to:
     connect easily through ordinary personal computers and local phone numbers;
     exchange electronic mail (E-mail) with friends and colleagues with accounts on the
        Internet;
     post information for others to access, and update it frequently;
     access multimedia information that includes sound, photographic images and even video;
        and
     Access diverse perspectives from around the world.
       An additional attribute of the Internet is that it lacks a central authority—in other words,
there is no "Internet, Inc." that controls the Internet. Beyond the various governing boards that
work to establish policies and standards, the Internet is bound by few rules and answers to no
single organization.
       Many people think that the Internet is a recent innovation, when in fact the essence of it has
been around for over a quarter century. The Internet began as ARPAnet, a U.S. Department of
Defense project to create a nationwide computer network that would continue to function even if
a large portion of it were destroyed in a nuclear war or natural disaster.
       During the next two decades, the network that evolved was used primarily by academic
institutions, scientists and the government for research and communications. The appeal of the
Internet to these bodies was obvious, as it allowed disparate institutions to connect to each
others' computing systems and databases, as well as share data via E-mail.
       The nature of the Internet changed abruptly in 1992, when the U.S. government began
pulling out of network management, and commercial entities offered Internet access to the
general public for the first time. This change in focus marked the beginning of the Internet's
astonishing expansion. The Internet is also the communications backbone underlying the World
Wide Web (WWW).
      If you connect to the Internet through an Internet Service Provider (ISP), you are usually
assigned a temporary IP address for the duration of your dial-in session. If you connect to the
Internet from a local area network (LAN) your computer might have a permanent IP address or it
might obtain a temporary one from a DHCP (Dynamic Host Configuration Protocol) server. In
any case, if you are connected to the Internet, your computer has a unique IP address.
       Protocol Stacks and Packets
      So your computer is connected to the Internet and has a unique address. How does it 'talk'
to other computers connected to the Internet? An example should serve here: Let's say your IP
address is 1.2.3.4 and you want to send a message to the computer 5.6.7.8. The message you
want to send is "Hello computer 5.6.7.8!". Obviously, the message must be transmitted over
whatever kind of wire connects your computer to the Internet. Let's say you've dialed into your
ISP from home and the message must be transmitted over the phone line. Therefore the message
must be translated from alphabetic text into electronic signals, transmitted over the Internet, and
then translated back into alphabetic text. How is this accomplished? Through the use of
a protocol stack. Every computer needs one to communicate on the Internet and it is usually
built into the computer's operating system (i.e. Windows, UNIX, etc.). The protocol stack used
on the Internet is referred to as the TCP/IP protocol stack because of the two major
communication protocols used. The TCP/IP stack looks like this:
    If we were to follow the path that the message "Hello computer 5.6.7.8!" took from our
computer to the computer with IP address 5.6.7.8, it would happen something like this:
      The message would start at the top of the protocol stack on your computer and work it's
       way downward.
      If the message to be sent is long, each stack layer that the message passes through may
       break the message up into smaller chunks of data. This is because data sent over the
       Internet (and most computer networks) are sent in manageable chunks. On the Internet,
       these chunks of data are known as packets.
      The packets would go through the Application Layer and continue to the TCP layer. Each
       packet is assigned a port number. We need to know which program on the destination
       computer needs to receive the message because it will be listening on a specific port.
      After going through the TCP layer, the packets proceed to the IP layer. This is where
       each packet receives its destination address, 5.6.7.8.
      Now that our message packets have a port number and an IP address, they are ready to be
       sent over the Internet. The hardware layer takes care of turning our packets containing the
       alphabetic text of our message into electronic signals and transmitting them over the
       phone line.
      On the other end of the phone line your ISP has a direct connection to the Internet. The
       ISPs router examines the destination address in each packet and determines where to send
       it. Often, the packet's next stop is another router.
      Eventually, the packets reach computer 5.6.7.8. Here, the packets start at the bottom of
       the destination computer's TCP/IP stack and work upwards.
      As the packets go upwards through the stack, all routing data that the sending computer's
       stack added (such as IP address and port number) is stripped from the packets.
      When the data reaches the top of the stack, the packets have been re-assembled into their
       original form, "Hello computer 5.6.7.8!"
Internet Congestion
      Internet congestion occurs when a large volume of data is being routed on low bandwidth
lines or across networks that have high latency and cannot handle large volumes. The result is
slowing down of packet movement, packet loss and drop in service quality.
      Congestion Collapse is the situation in which the congestion becomes so great that
throughput drops to a low level and thus little useful communication occurs.
      Various techniques have been developed in attempt to minimize congestion collapse in
communication networks. In addition to increasing capacity and data compression, they include
protocols for informing transmitting devices about the current levels of network congestion and
having them reroute or delay their transmissions according to congestion levels.
      Congestion Control The processes that are used to reduce congestion in a network. This
includes making decisions such as: deciding when to accept new Traffic, when to delete packets
and when to adjust the routing policies used in the network.
Internet Culture
      The Internet offers the hope of a more democratic society. By promoting a decentralized
form of social mobilization, it is said, the Internet can help us to renovate our institutions and
liberate ourselves from our authoritarian legacies. The Internet does indeed hold these
possibilities, but they are hardly inevitable. In order for the Internet to become a tool for social
progress, not a tool of oppression or another centralized broadcast medium or simply a waste of
money, concerned citizens must understand the different ways in which the Internet can become
embedded in larger social processes.
      In thinking about culturally appropriate ways of using technologies like the Internet, the
best starting-point is with people -- coherent communities of people and the ways they think
together.
      Let us consider an example. A photocopier company asked an anthropologist named Julian
Orr to study its repair technicians and recommend the best ways to use technology in supporting
their work. Orr took a broad view of the technicians' lives, learning some of their skills and
following them around. Each morning the technicians would come to work, pick up their
company vehicles, and drive to customers' premises where photocopiers needed fixing; each
evening they would return to the company, go to a bar together, and drink beer. Although the
company had provided the technicians with formal training, Orr discovered that they actually
acquired much of their expertise informally while drinking beer together. Having spent the day
contending with difficult repair problems, they would entertain one another with "war stories",
and these stories often helped them with future repairs. He suggested, therefore, that the
technicians be given radio equipment so that they could remain in contact all day, telling stories
and helping each other with their repair tasks.
      As Orr's story suggests, people think together best when they have something important in
common. Networking technologies can often be used to create a space for "communities of
practice", like the photocopier technicians, to think together in their own ways. This is perhaps
the most common use of the Internet: discussion groups organized by people who wish to pool
their information and ideas about a topic of shared interest. At the same time, we should not
consider the Internet in isolation. Regardless of whether they are located in the same geographic
region or distributed around the world, a community's members will typically think together
using several media, such as the telephone, electronic mail, printed publications, and face-to-face
meetings, and the Internet is best conceived as simply one component of this larger ecology of
media.
      Social networks also influence the adoption of new technologies: if the members of a
community already have social connections to one another than they are more likely to benefit
from technological connections. Every culture has its own distinctive practices for creating and
maintaining social networks, and a society will be healthier in political and economic terms
when these practices are functioning well.
      Authoritarian societies will attempt to suppress the cultural practices of networking, and
democratic societies will promote them. Broad implementation of the Internet is one way to
promote social networking, and the existing practices of networking can offer clues to the most
effective ways of implementing the Internet.
ISDN
      ISDNs are special digital telephone lines that can be used to dial into the Internet at speeds
ranging from 64 to 128 kbps. These types of connections are not available everywhere telephone
companies have to install special ISDN digital switching equipment. ISDNs require use of a
special "digital modem" that sends and receives digital signals over ISDN lines. With an ISDN,
the telephone line is divided into three channels (BRI - Basic Rate Interface), two-64 kbps B
(bearer) channels that send data and one 16 kbps D (data) channel that sends routing information.
This type of access is commonly referred to as 2B+D. To use the ISDN access to the Internet, an
ISP has to offer the ISDN access. ISDN lines cost more than normal phone lines, so the
telephone rates are usually higher.
Cable TV Connection
     Currently most households with cable TV have the option for cable modem Internet access.
The cable modem offers a high-speed link at low cost for unlimited, "always connected" access.
The connection speeds range from 128 kbps up to 10 mbps (megabits per second). A cable
modem is a device that connects to the existing TV cable feed and to an Ethernet network card in
the user's PC (also called an NIC - Network Interface Card). The cable network is designed to
support the highest speeds in the "downstream" direction, which is from the Internet to the client
computer. This downstream speed affects the performance of downloading Web pages and
software. The "upstream" bandwidth for data sent from a user's computer to the Internet is
typically less, in the range of 200 kbps to 2 mbps. The benefit of the cable modem for Internet
access is that, unlike DSL, its performance doesn't depend on distance from the central cable
office. However, with the cable TV network, the computer is put on a Local Area Network
(LAN) with other users in the neighborhood and like with any LAN, the performance degrades
as usage increases. A more disturbing issue is that of network security. One of the main purposes
of a LAN is to allow file sharing among the computers on the LAN. This LAN feature doesn't
work well with cable Internet access, as most users do not want neighbors accessing their files.
Turning the sharing option off can prevent file sharing. Also, installing the firewall hardware or
software may protect from hackers.
Satellite Connection
      Getting the Internet feed from a satellite is really not all that different from getting TV
signals from one. In both cases data is being sent from the satellite to a user's equipment and then
translated and decoded. One major limitation of satellite technology is that it can only send data
from the satellite to a user's receiver—not the other way. To get around this problem, a separate
ISP connection is needed to send data to the Internet, typically over an analog modem. This
connection works in conjunction with the satellite feed. As information is requested via the
modem line, data are sent back via the satellite. Since most Internet users need high bandwidth
from the Web, downstream (typically Web pages and file downloads), and less bandwidth going
to the Web, upstream (typically link requests), this scenario of sending upstream data over a
standard modem line and downstream data over the high-bandwidth satellite feed has been
effective. The newest satellite technology allows for two-way communications and higher
upstream bandwidths. A satellite return channel can be added for traffic bound for the Internet.
The upload speeds through this satellite return channel may peak at 128 kbps. Download speeds
with this system are up to 400 kbps. Satellite technology has one strong advantage over cable
modems and DSL: accessibility. For many it is today's only high-speed option. It can reach
areas that are otherwise difficult to establish contact with. The infrastructure exists to provide
400 kbps downstream bandwidth to almost anyone with a 21" satellite dish. It is eight times
faster than fastest analog telephone modems and three times faster than ISDN. However, it is not
as fast as cable modems or DSL services, which both can provide more than megabits of
bandwidth. Also, cable and DSL access methods are cheaper. Equipment required for satellite
connection includes installation of a mini-dish satellite receiver and a satellite modem. Like
cable modem systems, satellite provides a "shared bandwidth" pipe. This means that download
performance may vary depending upon other users of the satellite transponder. Another potential
problem can be associated with severe weather. In severe snowstorms and heavy rain, users may
experience signal fade.
      The general rule about the Internet connection is the faster, the better. The bandwidth and
transfer rate determine how quickly pictures, sounds, animation and video clips will be
downloaded. Since multimedia and interactivity make the Internet such an exciting tool for
information sharing, the speed is the key. Dial-up access provides an easy and inexpensive way
for users to connect to the Internet, however, it is a slow-speed technology and most users are no
longer satisfied with dial-up or ISDN connections. Fortunately, the broadband access, we once
dreamed of, is now possible with TV cable, DSL and satellite links.
Class A, B and C
     Based on the split of the 32 bits, an IP address is either Class A, B or C, the most common
of which is Class C. More than two million Class C addresses are assigned, quite often in large
blocks to network access providers for use by their customers. The fewest are Class A networks,
which are reserved for government agencies and huge companies.
Modems
     A modem is a Modulator/Demodulator. It connects a terminal/computer to the Voice
channel (dial-up line). A modem can establish two types of connections:
Digital connection The connection between the modem and the terminal/computer is a digital
connection.
Analog connection The connection between the modem and the phone line is an analog
connection.
Types of Modem
    Internal Modems are a plug-in circuit board that sits inside the computer. It incorporates
      the serial port on-board. They are less expensive than external modems because they do
      not require a case, power supply and serial cable
    External Modems sit next to the computer and connect to the serial port using a cable
Communication Software
      Communication software is used to provide remote access to systems and exchange files
and messages in text, audio and/or video formats between different computers or user IDs. This
includes terminal emulators, file transfer programs, chat and instant messaging programs.
Internet Tools
      The internet communication takes place in following three ways and communication tools
are selected on the basis as follows:
     One-to-One Communication This type of communication is very common on Internet
        and tools are:
             Email
             Chat type systems
     Large and Small Group Communication tools are:
             Social Networks
             Blogging
             Instant Messaging
             Chat
             Usenet
            Mail-based discussion list
       Mass Communication tools are:
           Net Video
           Net Audio
           Mass Media Outlets
Web Browser
       A "browser" is a tool which lets Internet users visit their favourite websites. It is a kind of
 software with a graphical interface which includes navigation buttons, an address bar, and a
 status bar (generally below the window). Most of its surface is used to display Web pages.
Some common Features of web browsers are listed below:
      Personal Preferences: Most browsers have a number of options that you can set. These
      are:
   1. Cookies you can ask to be notified before cookie is written and you can then decide
      whether or not to allow the cookie to be written.
   2. Disk Cache you can set the size of your cache
   3. Fonts you can select a font specification and also set a default font size.
   4. Helper applications
   5. Home page location
   6. Images
   7. JavaScript and Java
   8. Messages
    Bookmarks: A convenient feature of browsers allows you to save the URL of any Web
      page you display.
    Plug-ins: they extend the power of the browser.
Search engines
     Search engines ask for keywords or phrases and then search the Web for results. Some
search engines look only through page titles and headers. Others look through documents, such
as Google, which can search PDFs. Many search engines now include some directory categories
as well (such as Yahoo).
Metasearch engines
     These (such as Dogpile, Mamma, and Metacrawler) search other search engines and often
search smaller, less well known search engines and specialized sites. These search engines are
good for doing large, sweeping searches of what information is out there.
     A few negatives are associated with metasearch engines. First, most metasearch engines
will only let you search basic terms, so no Boolean operators or advanced search options.
Second, many metasearch engines pull from pay-per-click advertisers, so the results you get may
primary be paid advertising and not the most valid results on the web
Search Fundamentals
      The Internet contains a vast collection of information, which is spread out in every part of
the world on remote web servers. The problem in locating the correct information on the Internet
led to the creation of search technology, known as Internet Search Engine. A search engine can
provide links to relevant information based on your requirement or query. In order to understand
the terminology and techniques to position our web site pages for higher ranking in search
engines, the knowledge of the basic functioning of a search engine is essential.
Search Strategies
     Search engines are good for finding sources for well-defined topics. Typing in a general
term such as "education" or "Shakespeare" will bring back far too many results, but by
narrowing your topic, you can get the kind (and amount) of information that you need.
Example:
     Go to Google (a search engine)
     Type in a general term ("education")
      Add modifiers to further define and narrow your topic ("rural education Indiana")
      Be as specific as you can ("rural education Indiana elementary school")
      Submit your search.
Looking for information about job opportunities? Look at some of the sites listing job
vacancies. Try university websites that sometimes list jobs through their placement offices, or try
professional organizations which also sometimes list jobs in that field. Or look through the
websites of various large companies because they usually have a section on job opportunities in
their company.
Looking for information likely to be discussed on newsgroups or chat rooms? Look through
the lists of newsgroups or use a search engine.
Looking for information about a current topic? Check the newspaper and current
newsmagazine sites. Most have a search engine for articles in their publications.
Looking for data that might have been collected on a government site? Start with sites such
as the Library of Congress or The White House.
Telnet
      Telnet is a network protocol used on the Internet or local area networks to provide a
bidirectional       interactive     text-oriented     communications      facility    using      a
virtual terminal connection. User data is interspersed in-band with Telnet control information in
an 8-bit byte oriented data connection over the Transmission Control Protocol (TCP).
      Telnet was developed in 1969 beginning with RFC 15, extended in RFC 854, and
standardized as Internet Engineering Task Force (IETF) Internet Standard STD 8, one of the first
Internet standards.
      Historically, Telnet provided access to a command-line interface on a remote host. Most
network equipment and operating systems with a TCP/IP stack support a Telnet service for
remote configuration (including systems based on Windows NT). Because of security issues with
Telnet, its use for this purpose has waned in favor of SSH.
      The term telnet may also refer to the software that implements the client part of the
protocol. Telnet client applications are available for virtually all computer platforms. Telnet is
also used as a verb. To telnet means to establish a connection with the Telnet protocol, either
with command line client or with a programmatic interface. For example, a common directive
might be: "To change your password, telnet to the server, login and run the passwd command."
Most often, a user will be telnetting to a Unix-like server system or a network device (such as a
router) and obtain a login prompt to a command line text interface or a character-based full-
screen manager.
      Telnet is a client-server protocol, based on a reliable connection-oriented transport.
Typically this protocol is used to establish a connection to Transmission Control
Protocol (TCP) port number 23, where a Telnet server application (telnetd) is listening. Telnet,
however, predates TCP/IP and was originally run over Network Control Program (NCP)
protocols.
      Because of negotiable options protocol architecture, many extensions were made for it,
some of which have been adopted as Internet standards, IETF documents STD 27 through STD
32. Some extensions have been widely implemented and others are proposed standards on the
IETF standards track.
      Experts in computer security, such as SANS Institute, recommend that the use of Telnet for
remote logins should be discontinued under all normal circumstances, for the following reasons:
   Telnet, by default, does not encrypt any data sent over the connection (including passwords),
    and so it is often practical to eavesdrop on the communications and use the password later
    for malicious purposes; anybody who has access to a router, switch, hub or gateway located
    on the network between the two hosts where Telnet is being used can intercept the packets
    passing by and obtain login, password and whatever else is typed with a packet analyzer.
   Most implementations of Telnet have no authentication that would ensure communication is
    carried out between the two desired hosts and not intercepted in the middle.
   Commonly used Telnet daemons have several vulnerabilities discovered over the years.
      These security-related shortcomings have seen the usage of the Telnet protocol drop
rapidly, especially on the public Internet, in favor of the Secure Shell (SSH) protocol. SSH
provides much of the functionality of telnet, with the addition of strong encryption to prevent
sensitive data such as passwords from being intercepted, and public key authentication, to ensure
that the remote computer is actually who it claims to be. As has happened with other early
Internet protocols, extensions to the Telnet protocol provide Transport Layer Security (TLS)
security and Simple Authentication and Security Layer (SASL) authentication that address the
above issues. However, most Telnet implementations do not support these extensions; and there
has been relatively little interest in implementing these as SSH is adequate for most purposes.
   ASCII mode: used for text. Data is converted, if needed, from the sending host's character
    representation to "8-bit ASCII" before transmission, and (again, if necessary) to the receiving
    host's character representation. As a consequence, this mode is inappropriate for files that
    contain data other than plain text.
   Image mode (commonly called Binary mode): the sending machine sends each file byte for
    byte, and the recipient stores the bytestream as it receives it. (Image mode support has been
    recommended for all implementations of FTP).
   EBCDIC mode: use for plain text between hosts using the EBCDIC character set. This mode
    is otherwise like ASCII mode.
   Local mode: Allows two computers with identical setups to send data in a proprietary format
    without the need to convert it to ASCII
      For text files, different format control and record structure options are provided. These
features were designed to facilitate files containing Telnet or ASA formatting.
Data transfer can be done in any of three modes:
   Stream mode: Data is sent as a continuous stream, relieving FTP from doing any processing.
    Rather, all processing is left up to TCP. No End-of-file indicator is needed, unless the data is
    divided into records.
   Block mode: FTP breaks the data into several blocks (block header, byte count, and data
    field) and then passes it on to TCP. [5]
   Compressed mode: Data is compressed using a single algorithm (usually run-length
    encoding).
Coast-to-Coast Surfing
      The Web provides a means of accessing an enormous collection of information, including
text, graphics, audio, video, movies, and so on. One of the most exciting aspects of the Web is
that information can be accessed in a nonlinear and experimental fashion. Unlike reading a book
by flipping to the next page in sequential order, you can “jump” from one topic to another via
hyperlinks. This nonlinear approach to information gathering, or browsing is sometimes referred
to as “coast-to-coast surfing”.
HTML
    HyperText Markup Language (HTML) is the predominant markup language for web pages.
 HTML elements are the basic building-blocks of web pages.
 HTML Tags
 HTML markup tags are usually called HTML tags
    HTML tags are keywords surrounded by angle brackets like <html>
    HTML tags normally come in pairs like <b> and </b>
    The first tag in a pair is the start tag, the second tag is the end tag
    Start and end tags are also called opening tags and closing tags
       HTML elements form the building blocks of all websites. HTML allows images and
 objects to be embedded and can be used to create interactive forms. It provides a means to
 create structured documents by denoting structural semantics for text such as headings,
 paragraphs, lists, links, quotes and other items. It can embed script sin languages such
 as JavaScript which affect the behavior of HTML web pages.
       Web browsers can also refer to Cascading Style Sheets (CSS) to define the appearance and
 layout of text and other material. The W3C, maintainer of both the HTML and the CSS
 standards, encourages the use of CSS over explicitly presentational HTML markup.
Basic Principles
Basic principles for web page installation are:
      You need to have Web pages to publish.
      A Web Server where the files must be placed must be available to you.
      The permissions on the files need to be set so that any user anywhere can read them.
      When someone requests your web page, the server has to deliver it.
      Head tag The <HEAD> tag has no attributes. Several other tags can be included inside it.
      Basefont tag The <BASEFONT> tag defines the font size to be used in the HTML
       document and may be included in the head of the document.
      Base tag The <BASE> tag is useful for setting some global parameters of an HTML
       document and may be included in the head of the document. A global parameter is an
       attribute that has an effect on the entire document.
      Meta tag etc. The <META> tag is used to include additional information about a
       document and can be used to pass additional information to a browser. There is no ending
       for a <META> tag and a document can have multiple <META tags.
Basics of HTML
HTML is short for HyperText Markup Language.
   Hypertext is simply a piece of text that works as a link.
   Markup Language is a way of writing layout information within documents.
       Basically an HTML document is a plain text file that contains text and nothing else. When
a browser opens an HTML file, the browser will look for HTML codes in the text and use them
to change the layout, insert images, or create links to other pages. Since HTML documents are
just text files they can be written in even the simplest text editor
Web Pages
Web pages have many uses. Here are some important facts about why web pages are so useful.
   A cheap and easy way to spread information to a large audience.
   Another medium to market your business.
      Let the world know about you with a personal website!
Words to Know
    Tag - Used to specify ("mark-up") regions of HTML documents for the web browser to
      interpret. Tags look like this: <tag>
    Element - A complete tag, having an opening <tag> and a closing </tag>.
    Attribute - Used to modify the value of the HTML element. Elements will often have
      multiple attributes.
    For now just know that a tag is a command the web browser interprets, an element is a
complete tag, and an attribute customizes or modifies HTML elements.
Example
<head>
<title>Title of the page
</title>
</head>
It's a basic example of using <head> tag. On the picture you may see title of page, determined in
<title> tag.
Example
<head>
<base href="http://yoursite.com/www/" target="_blank">
<basefont face="sans-serif" color="darkblue">
<title>Example of head tag</title>
</head>
      This example shows how you can use <head> tag for basic formatting of web-page. You
will receive the page with sans-serif dark blue font of text. All links will be open in new window.
      The body tag can be used to control the background color of the document by setting the
attribute "bgcolor" using a hex value (see the tutorial on Colors for details). You can add other
attributes to control the link and text colors and they will be the defaults for the web page you are
attempting to build. Additionally, you can set an image to become the background through the
background attribute. For the image to load in all popular browsers, it is recommended to be in
the jpeg format as it generally loads faster than gif or png images.
      If image is not found or browser don't show pictures, image will not appeared. Background
will have color which determines by "bgcolor" tag.
Formatting
HTML Text Formatting Tags: There are 3 types of text formatting tags:
<i> Makes the text appear as italic (Identical to the <em> tag).
Example
<i>Italics Text</i>
Italics Text
<b> Makes the text appear as bold text (Identical to the <strong> tag).
Example
<b>Bold Text</b>
Bold Text
You can also combine any of these tags together for a "mixed" result:
<b><big>Bold Big Text</big></b>
Bold Big Text
<q> Used to display short quotations. Will automatically place quotations around the text.
Example
<q>
Here we have a small quotation. This tag will automatically place quotations around the text.
</q>
Here we have a small quotation. This tag will automatically place quotations around the text.
<p> Used to define a paragraph.
Example
<p>
Paragraph Text goes here
</p>
Paragraph Text goes here.
<br /> Used to insert a single line break in the text. (There is no end tag, so <br><br /> is
wrong).
Example
I am on one line and <br /> then I am on another.
I am on one line and
then I am on another.
Header Tags
<h1> Makes the text appear as the largest header.
<h6> Makes the text appear as the smallest header.
Example
<h1>Header 1</h1>
Header 1
<h2>Header 2</h2>
Header 2
<h3>Header 3</h3>
Header 3
<h4>Header 4</h4>
Header 4
<h5>Header 5</h5>
Header 5
<h6>Header 6</h6>
Header 6
Hyperlinks
      Hyperlinks can take the form of linking to one web page to another web page, opening an
email or FTP client, or call for some other action. They are how we get from point A to point B
on the World Wide Web; they are what make the web user friendly and convenient. A hyperlink
can also move you from one point to another within a single page by using the "#" symbol.
Creating Hyperlinks
     We use <A> element (A stands for anchor) to create hyperlinks in HTML. The most
common form of hyperlink is undoubtedly the text hyperlink, where the hyperlink itself usually
appears underlined and in a different color from the surrounding text to see it off from that text.
     <BODY>
          <CENTER>
            <H1>
                Creating A Hyperlink
            </H1>
            Here is a Website to Check Out...
            <A HREF="HTTP://W3C.ORG">W3C</A>!
          </CENTER>
     </BODY>
</HTML>
<HTML>
    <HEAD>
         <TITLE>
           Creating A Graphical Hyperlink
            </TITLE>
       </HEAD>
       <BODY>
            <CENTER>
              <H1>
                  Creating A Graphical Hyperlink
              </H1>
                <A HREF="http://W3C.ORG">
                    <IMG    WIDTH=110         HEIGHT=110              SRC="C:\Documents         and
Settings\Meenakshi\My Documents\My Pictures\flowers.gif"
                      ALT="Click me to go to W3C">
                </A>
              </CENTER>
        </BODY>
</HTML>
The results of this HTML appear in following figure. When the user clicks the image in the
figure, the browser navigates to the hyperlink’s target, http://W3C.org
Example
<HTML>
<HEAD>
     <TITLE>
       Linking to A Section In A Page
     </TITLE>
</HEAD>
<BODY>
      <CENTER>
       <H1>
         Linking to A Section In A Page
       </H1>
       Click here to go to the
       <A HREF="#BOTTOM">bottom</A>
       of the Page.
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
      <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <BR>
          <HR>
            <A NAME="BOTTOM">This is the bottom of the page.</A>
          </CENTER>
     </BODY>
</HTML>
<HTML>
    <HEAD>
         <TITLE>
           Creating Graphical Navigational Aids
         </TITLE>
    </HEAD>
    <BODY>
     <CENTER>
         <H1>
           Creating Graphical Navigationa Aids
         </H1>
         Want to get somewhere fast? Click a button below...
              <BR>
              <A HREF="prev.html">
                    <IMG    WIDTH=172         HEIGHT=117            SRC="C:\Documents         and
Settings\Meenakshi\My Documents\My Pictures\left.gif"
                       ALT="Previous" BORDER=0>
              </A>
               <A HREF="index.html">
                    <IMG     WIDTH=161        HEIGHT=105         SRC="C:\Documents       and
Settings\Meenakshi\My Documents\My Pictures\home.gif"
                       ALT="Home" BORDER=0>
               </A>
<A HREF="next.html">
                    <IMG     WIDTH=172        HEIGHT=117         SRC="C:\Documents       and
Settings\Meenakshi\My Documents\My Pictures\right.gif"
                       ALT="Next" border=0>
               </A>
           </CENTER>
        </BODY>
</HTML>
Toolbar
Text
      Entering text into a webpage is much like entering text into a word processor. Simply type
the text you want to appear and then use the following steps to spice it up.
Layout
    The text on your webpage doesn't have to all be in paragraph blocks. You do something:
   Line Break
   When you press ENTER at the end of a line of text, the cursor drops down two lines and
   starts a new paragraph. The only way to get text directly underneath the first line of text
   is to finish filling up the line and letting word-wrap do the rest But sometimes you want
   to go to the very next line after only a few words. An example of this is a centered
   heading:
                                Jenny Kiaschko
                                Ed Psy 490NET
       This is called a Line Break. To create a line break, simply hold down the SHIFT key
        and press ENTER.
       Alignment
        You can align text and pictures to the right, center, or left of your webpage. To do this,
        highlight the text or picture you want to move and click on either the right, center, or left
        buttons on the toolbar. If you haven't started typing the text, just click on either the right,
        center, or left buttons and the cursor will move to that part of the page.
       Indents
        You can indent blocks as text as well. To indent some text, click the Increase Indent
        Icon on the toolbar. To out-dent or un-indent some text, click the Decrease Indent
        Icon on the toolbar. When you indent or out-dent a block of text, the entire paragraph that
        the text is in is indented or out-dented. So be careful when using indent and out-dent,
        especially inside of lists.
Lists
      You can also make lists. Lists are indented and denoted and are especially good for
outlines. Here is an example of the two major kinds of lists, the Numbered List and
the Bulleted List:
            Numbered List                            Bulleted List
                           Apples                               o   Dogs
                           Oranges                              o   Cats
                           Kiwi                                 o   elephants
                           Tomatoes                             o   Sheep
To make a list, select either the Numbered List or Bulleted List Icon from the toolbar. Type the text of the fi
In the case of outlines, you may want to nest lists, or have a list inside of another list. It would look something like
               Math Department
               o
               
               Calculus
               
               
               Jenny Kiaschko
               Nancy Pence
               Algebra
               
               
               Matt Reed
               Joby Crum
               Geometry
               
               
               Robin Ehrhart
               Jenny Kiaschko
               Erin Scheffler
               Science Department
                 and so...
build a nested list, start by creating the top most list, or parent. (In the case above, you'd make
a Numbered List and type in the first item.) Then to make a sub-list of that item, do the
following:
           o Press ENTER after typing in the list item of the parent list.
           o Click the Increase Indent Icon.
           o Select the either the Numbered List or Bulleted List Icon from the toolbar. (In
             the case above, you'd select Numbered List.)
           o Type in the first item of the nested list.
     To end a sub-list and return to its parent list (In the example above, end the list
containing Mike Loosbrock and Matt Christians and get back to list containing Work
Study, Part-Time Employees, and Staff), do the following:
Attributes
     FrontPage Express allows you to make all the same attribute changes you can make in
Word97. The first step in changing text attributes is to highlight the text you want to modify with
the mouse. You can then make the following changes:
   1. Font Type
      Font type is the font family of text, such as Comic Sans, Times New Roman, and Courier
      New. To change the font type, select the font you want from the Font Type List Box on
      the toolbar. (Try not to use a lot of non-standard fonts because if the font is not loaded on
      the computer where your page is being viewed, the font will appear as the browser
      default.)
   1. Font Style
      The style of the text can either be bold, italics, or underline. To change the font style,
      select one or more of the Style Icons on the toolbar.
       Font Color
      The color of the text can also be changed. To change the font color, select the Text Color
      Icon on the toolbar. The Color Dialog Box appears. Choose the color you want and click
      OK.
    Font Size
      You       can      change       the     font     size     by     clicking       the     either
      the Increase TextSize or Decrease Text Size Icon from the toolbar.
Images
     You can insert images (*.gif, *.jpg, *.bmp) into your webpage. Keep in mind that you
need to keep your images relatively small in size, otherwise, your pages will take a long time to
download.
     To insert an image, put your cursor where you want to place the image and then:
   1) Select the Insert Image icon from the toolbar.
   2) The Image Dialog Box appears. Click the Browse Button.
   3) Find and select the image you wish to insert and click OK.
     The image should appear on the webpage. After you have placed the image on the
webpage, you can change the attributes of the image by right clicking on the image and
choosing Image Properties.
The Image Properties Dialog Box appears. Choose the Appearance Tab.
Links
      Links create a connection between more than one of your pages. Links also can connect
your page to other pages across the World Wide Web.
      To link to a webpage other than your own, determine where yo u want to link to (For
example, you might want the viewer to click on the words "CNN News" and have them sent
to http://www.cnn.com). To do this, first highlight the text, picture, or both, that you want to be
linked (in this case, we would highlight the words "CNN News"). Next click the Create or Edit
Hyperlink Icon on the toolbar.
      The Create Hyperlink Dialog Box should appear, as below. Choose the World Wide Web
tab. Then make sure the Hyperlink Type List Box is set to "http:" on the Hyperlink Type List
Box. Lastly, on the line titled URL type the address of the webpage. In this case we would type
out http://www.cnn.com. Click the OK and you have just created a link that should look and
work something like this link: CNN News.
      To link your own pages together, you first need to determine how the pages are to be
connected. For example, you may want the viewer to click on the word "Hobbies", and have it go
to a separate page of yours. To do this, follow the same directions as above: highlight the text
and click the Create or Edit Hyperlink Icon on the toolbar.
      The Create Hyperlink Dialog Box should appear, as below. Choose the World Wide Web
tab. Next, select "(other)" for the Hyperlink Type:. On the URL line type the name of your
other page. In this case we would type "hobbies.htm". Once that is done you can click the OK
and you will have created a link to another one of your pages.
Special Features
The one line text box allows you to add a box for interactive typing, such as the one below.
The scrolling text box allows you to add a scrolling text box for more information than a one line text box
The check box allows you to add a box to gather information in a yes/no format.
Please Vote for One Person
Jennifer
  Jason
    Brian
The radio button box gives you the same capabilities as the check box only in a radio button
form.
Please Vote for One Teacher
    Jim Levin
    Sandy Levin
    Michael Waugh
The drop down menu box allows you to give a list of choices in a compressed amount of space.
                  Jennifer
                  Jason
The push button box allows you to add a button for different tasks: submit or reset.
 Submit   Reset
      The tools listed above are extremely useful because it allows you to add higher level
features to your web page without having to know any type of coding.
Plug-ins
     In computing, a plug-in (or plug-in) is a set of software components that adds specific
capabilities to a larger software application. If supported, plug-ins enables customizing the
functionality of an application. For example, plug-ins is commonly used in web browsers to play
video, scan for viruses, and display new file types. Well-known plug-ins examples include
Adobe Flash Player and QuickTime.
Applications support plug-ins for many reasons. Some of the main reasons include:
     to enable third-party developers to create capabilities which extend an application
     to support easily adding new features
     to reduce the size of an application
     to separate source code from an application because of incompatible software licenses
Section C: Languages
Basic and Advanced HTML
     <BODY>
          Here is a line of text.
          <BR>
          Using the < BR > tag skips to the next line.
          <P>
          On the other hand, using the < P> tag
          starts a new paragraph.
          </P>
     </BODY>
</HTML>
              <P>
               Dear You:
              <DIV ALIGN="CENTER" STYLE="color: red; font-style: italic">
               When are you going to ship my order?
              </DIV>
          <DIV ALIGN="RIGHT">
             <P>
             President
             <BR>
             NeedItNow, Inc.
             <BR>
             Speedy, CO
          </DIV>
     </BODY>
</HTML>
On the other hand <SPAN> can be used to mark sections of text inline or text in the midst of the
other text. For example:
<HTML>
<HEAD>
                <TITLE>
                   Using the <SPAN> tag
                </TITLE>
        </HEAD>
       <BODY>
          This is <SPAN STYLE="font-style: italic">not</SPAN> going to do!
       </BODY>
</HTML>
<HTML>
<HEAD>
<TITLE>
Using the FONT tag
</TITLE>
</HEAD>
<BODY>
<FONT SIZE=6 COLOR="RED" FACE="Arial">Here is some text.</FONT>
</BODY>
</HTML>
The results appear in the following figure:
Setting the Base Font - <BASEFONT>
This element sets the font for the default text enclosed in the element, replacing the default font used by the bro
<FONT> tag. In the following example, I’m setting the base font size to 4 (possible values range from 1 through
<HTML>
<HEAD>
<BASEFONT SIZE=4>
<TITLE>
Using the BASEFONT tag
</TITLE>
</HEAD>
<BODY>
Hereissome<FONTSIZE="+2"COLOR="RED"
FACE="Arial">bigger</FONT>text.
</BODY>
</HTML>
<HTML>
<HEAD>
<BASEFONT SIZE=4>
<TITLE>
Using the BLINK tag
</TITLE>
</HEAD>
<BODY>
<BLINK> Happy New Year!!! </BLINK>
</BODY>
</HTML>
The results appear in the figure given below:
Note:- This tag is not supported by all the browsers.
Here is an example showing a number of ways to display and align horizontal rules:
<HTML>
        <HEAD>
              <TITLE>
                 Using the <HR> tag
              </TITLE>
        </HEAD>
        <BODY>
              Here is what <Hr> looks like:
              <HR>
              <BR>
              Here is what <HR ALIGN=LEFT WIDTH=80%> looks like:
              <HR ALIGN=LEFT WIDTH=80%>
              <BR>
              Here is what <HR ALIGN=CENTER WIDTH=80%> looks like:
              <HR ALIGN=CENTER WIDTH=80%>
              <BR>
              Here is what <HR ALIGN=RIGHT WIDTH=10> looks like:
              <HR ALIGN=RIGHT WIDTH=10>
              <BR>
              Here is what <HR SIZE=10 NOSHADE> looks like:
              <HR ALIGN=CENTER SIZE=10 NOSHADE>
        </BODY>
</HTML>
    <BODY>
         <MARQUEE ALIGN="TOP" LOOP="INFINITE" BEHAVIOR="BOUNCE"
BGCOLOR="GREEN" DIRECTION="RIGHT">
         <H2>
           Here's a marquee!
         </H2>
         </MARQUEE>
              <CENTER>
              <H1>
                Using Marquees
              </H1>
              </CENTER>
     </BODY
</HTML>
ALT (text)
The "alt" attribute defines an alternate text designed to be a textual replacement for objects that
are usually not supported by some browsers. It also serves as additional information for browsers
that do support these objects (images, forms and applets). Browsers may display this text as a
tool tip when the mouse is over the object.
ALIGN
This attribute specifies the alignment of the element. These three values set the element's
position with respect to the surrounding text.
     bottom: Means that the bottom of the object should be vertically aligned with the current
        baseline. This is the default value.
      middle: Means that the center of the object should be vertically aligned with the current
       baseline.
    top: Means that the top of the object should be vertically aligned with the top of the
       current text line.
These two values set the position of a floating element:
    left: Cause the image to float to the current left margin.
    right: Cause the image to float to the current right margin.
WIDTH (length)
Assigns a width to the element.
HEIGHT(length)
Assigns a height to the element.
BORDER (pixels)
Specifies the element's border width.
 HSPACE (pixels)
This attribute works as a margin for the element, defining the amount of white space to be
inserted at the left and right sides of the element.
VSPACE (pixels)
This attribute works as a margin for the element, defining the amount of white space to be
inserted at the top and bottom sides of the element.
<HTML>
<BODY>
    <H2>Norwegian Mountain Trip</H2>
    <IMG BORDER="0" SRC="/images/pulpit.jpg"              ALT="Pulpit    rock" WIDTH="304"
HEIGHT="228" >
</BODY>
</HTML>
The result is shown below:
Unordered Lists
You can create unordered lists with elements like <UL>. Each item in the list gets its own
element using the <LI> list item tag. Here is an example showing how to create a bulleted list:
<HTML>
       <HEAD>
               <TITLE>
                 An Unordered List
               </TITLE>
       </HEAD>
       <BODY>
               <H1 ALIGN=CENTER>
              Creating an Unordered List
               </H1>
               Here are some items to consider when buying a computer:
               <UL>
                 <LI> Speed
                 <LI> Cost
                 <LI> RAM
            <LI> Disk Space
            <LI> CD ROM Speed
          </UL>
     </BODY>
</HTML>
Ordered Lists
    While unordered lists display a simple bullet before each list item, ordered lists use a
number system or alphabets to indicate that the items are ordered in some way. For example:
<HTML>
      <HEAD>
              <TITLE>
                An Ordered List
              </TITLE>
      </HEAD>
      <BODY>
              <H1 ALIGN=CENTER>
                Creating an Ordered List
              </H1>
              Here are some items to consider when buying a computer:
              <OL>
                <LI> Speed
            <LI> Cost
            <LI> RAM
            <LI> Disk Space
            <LI> CD ROM Speed
          </UL>
     </BODY>
</HTML>
Definition Lists
These lists include both terms and their definitions. <DL> element is used to create these lists,
<DT> for terms, and <DD> for the definition of each term. For example:
<HTML>
    <HEAD>
         <TITLE>
           A Definition List
         </TITLE>
    </HEAD>
    <BODY>
         <H1 ALIGN=CENTER>
           Creating a Definition List
         </H1>
             Here are some items to consider when buying a computer:
             <DL>
               <DT> Speed <DD> CPU speed in Megahertz.
               <DT> Cost <DD> Make sure to keep this down.
<DT> RAM <DD> Amount of memory in the computer.
<DT> Disk Space <DD> Get plenty of Gigabytes.
<DT> CD ROM Speed <DD> Get at least 24X
</DL>
</BODY>
</HTML>
Creating Tables
<TABLE> element is used to create tables. It encloses elements like <CAPTION>, <TR>,
      Constructing an HTML table consists of describing the table between the beginning table
tag, <TABLE>, and the ending table tag,</TABLE>. Between these tags, you then construct
each row and each cell in the row. To do this, you would first start the row with the beginning
row tag, <TR>, and then build the row by creating each cell with the beginning cell tag, <TD>,
adding the data for that cell, and then closing the cell with the ending cell tag, </TD>. When you
finish all of the cells for a row, you would then close the row with the ending row
tag, </TR>.Then, for each new row, you would repeat the process of beginning the row, building
each cell in the row, and closing the row.
      The following table is an example of a basic table with three rows and two columns of
data.
        Data 1 Data 2
        Data 3 Data 4
        Data 5 Data 6
The codes that generated this table look like this:
<TABLE>
        <TR>
                  <TD>Data 1</TD>
                 <TD>Data 2</TD>
        </TR>
        <TR>
                  <TD>Data 3</TD>
                <TD>Data 4</TD>
        </TR>
        <TR>
                 <TD>Data 5</TD>
                 <TD>Data 6</TD>
        </TR>
</TABLE>
     This table contains no border, title, or headings. If you wish to add any of these elements
to your table, you need to include additional HTML codes.
TABLE TITLE
Column A Column B
Data 1   Data 2
Data 3   Data 4
Data 5   Data 6
      The following codes generated the border, TABLE TITLE, and Column A and Column B
 headings for this table:
 <TABLE BORDER="5">
        <TR>
                <TH COLSPAN="2">
                <H3><BR>TABLE TITLE</H3>
                </TH>
        </TR>
                <TH>Column A</TH>
                <TH>Column B</TH>
       Notice     that    the    beginning     table   tag, <TABLE>,          now      includes      the
 border tag, BORDER="5", which places a border around the table and frames each cell. The
 number that you ascribe to the border tag, BORDER=n, sets the width of the table border.
 Depending on how you design your table, you can then determine the border size that best suits
 your table and the overall design of your web page.
       To add a title to your table, you would place the title and the attributes of that title between
 the row commands, <TR> and </TR>. The heading codes, <TH> and </TH>, define a heading
 cell and, by default, these codes center the heading and set it in bold type. However, if you want
 the title to span across the columns below it, you need to include the COLSPAN=n code. Since
 this table has two columns, the COLSPAN="2" code was necessary. To add emphasis to the
 header, you can use the header commands to make the text larger. In this table, notice that
 the <H3> and </H3> commands made the title larger. Finally, the <BR> tag created a
 space
above the title.
      The individual column headings are also described by the heading
codes, <TH> and </TH>. Since these codes, by default, center the heading and set it in bold
type, no additional commands or attributes were included in the heading commands.
Polishing your table
      To give your table a more polished look, you can include commands that will adjust the
size of your table, add space in the cell, add space between rows, and align the data in a cell.
Working with these commands is basically a process of trial and error to create the most
appealing presentation of your information. The type of table that you create and the overall
design of your web site will help you determine what works best for your table.
Some of the commands that enable you to customize your table include:
    The WIDTH=n% command sets the width of your table as a percentage of the screen.
      The letter n designates the percentage that you assign to this command. For example, if
      you want the width of your table to be one half the width of the screen, you would
      include the WIDTH="50%" command in the beginning table command.
    The CELLPADDING=n command adjusts the vertical dimension of the cells. The
      letter n designates the numerical value that you assign to this command.
    The CELLSPACING=n command sets the space or border around the cells. The
      letter n designates the numerical value that you assign to this command.
    The ALIGN=(LEFT, RIGHT, or CENTER) command will horizontally align the data in
      a cell. For example, if you wish to place the data in the center of each cell in a row, you
      would include the ALIGN=CENTER command within the row command.
    The VALIGN=(TOP, MIDDLE, or BOTTOM) command will vertically align the data in
      a cell. For example, if you wish to place the data in the center of each cell in a row, you
      would include the ALIGN=MIDDLE command within the row command.
 TABLE TITLE
 Column A                 Column B
 Data 1                   Data 2
 The following codes, along with codes previously discussed, created this table:
 <TABLE BORDER="5" WIDTH="50%" CELLPADDING="4"
 CELLSPACING="3">
       <TR>
              <TH COLSPAN="2"><BR><H3>TABLE TITLE</H3>
              </TH>
       </TR>
        <TR>
               <TH>Column A</TH>
               <TH>Column B</TH>
     </TR>
     <TR ALIGN="CENTER">
           <TD>Data 1</TD>
           <TD>Data 2</TD>
     </TR>
</TABLE>
     Notice that the TABLE command now includes the WIDTH="50%" command. This
command extends the table across one half of the width of the text. Also,
the CELLPADDING="4" command increases the vertical dimension of the cells, and
the CELLSPACING="3"command increases the border around the cells. Finally,
the ALIGN="CENTER" command places Data 1 and Data 2 in the center of the cell.
<HTML>
     <HEAD>
           <TITLE>Computer Services</TITLE>
     </HEAD>
        <FRAMESET COLS="30%,70%">
        <FRAME scrolling=yes SRC="links.html" NAME="left">
        <FRAME SRC="intro.html" NAME="right">
        </FRAMESET>
</HTML>
      The FRAMESET COLS code sets up the frame size starting from left to right. So from
this example, you can see that the left frame will take up 30% of the page's width and the right
frame will take up 70% of the page's width.
       In this case, the left frame will automatically contain a scroll bar, indicated by the FRAME
SCROLLING=YES code. This frame will display the file called links.html, indicated by the
source code shown as SRC. Finally, the NAME code indicates that the frame is appropriately
called left.
      The right frame will not automatically contain a scroll bar since the SCROLLING code is
not included. (A scrolling bar will appear, however, if it is needed.) This frame will display the
file called intro.html and the name of this frame is right.
Note that the even though the example uses the NAME code, assigning names to the frames is
not required. It is helpful, however, to include it because the names give you as an easy way to
indicate in which frame you wish to target information.
      So to recap, our sample code indicates that the file intro.html will contain introductory
material and will appear in the right frame when the web page opens. No frame codes are needed
in the intro.html file since it is simply an html file that displays in the right frame. A sample
intro.html file might look like this:
<HTML>
     <HEAD>
            <TITLE>Computer Services</TITLE>
     </HEAD>
     <BODY>
     <P align=Center>
     <IMG SRC="deptbanner.GIF">
     <H1><Center>Computer Services</Center></H1>
     <H3><Center>Introduction</Center></H3>
     <P align=Center>
             The Computer Services Department is responsible for supporting all the
             company's computers and networks and providing information services such as
             computer seminars, technical documentation, and publications.
     </BODY>
</HTML>
      Now that you have the information that will automatically open in the right frame, you can
continue by creating a file for the left frame.
Targeting information
      The left frame will contain a file called links.html which will include links to other pages.
When someone clicks on a link, however, you can set it up so that the information appears in the
right frame.
      To target information to the right frame, you must include the proper codes as shown in the
example file below:
<HTML>
   <HEAD>
      <TITLE>Computer Services</TITLE>
  </HEAD>
  <BODY>
      <H3>Computer Services Topics</H3>
      <P ALIGN=left>
      <A HREF="intro.html" target="right">Introduction</A> <P>
      <A HREF="helpdesk.html" target="right">Help Desk</A> <P>
      <A HREF="seminars.html" target="right">Seminars</A> <P>
   </BODY>
</HTML>
      In the sample code, you can see the standard A HREF code is used to create a link. This
linking code also contains the target code which indicates where you want to display the
information. Our sample file is set up so that when someone selects a link, the resulting file
appears in the right frame. This is evident by the fact that the target tag is set to "right," which is
the name you assigned to the right frame in the index.html file. In addition, note that the
file intro.html appears not only when the web page opens, but also when you click on the
link Introduction in the left frame. It also assumes that you have created a helpdesk.html file
and a seminars.html file with all the relevant information.
     Keep in mind, however, that if you set the link to a page that also has frames, the entire
page will be shown in the target frame, and you will have frames within frames. To avoid this,
don't set the link to appear in a frame. Instead, have it appear in its own window by eliminating
the target tag as in this example:
<A HREF="http://www.cnn.com">
JavaScript Language
What is JavaScript?
   JavaScript was designed to add interactivity to HTML pages
   JavaScript is a scripting language
   A scripting language is a lightweight programming language
   JavaScript is usually embedded directly into HTML pages
   JavaScript is an interpreted language (means that scripts execute without preliminary
      compilation)
<HTML>
     <BODY>
          <H1>My First Web Page</H1>
          <SCRIPT TYPE="text/javascript">
              document.write("Hello World!”);
          </SCRIPT>
</BODY>
</HTML>
    To insert a JavaScript into an HTML page, we use the <SCRIPT> tag. Inside the
<SCRIPT> tag we use the TYPE attribute to define the scripting language. So, the <SCRIPT
TYPE="text/javascript"> and </SCRIPT> tells where the JavaScript starts and ends.
JavaScript Statements
Unlike HTML, JavaScript is case sensitive.
A JavaScript statement is a command to a browser. The purpose of the command is to tell the
browser what to do.
Following JavaScript statement tells the browser to write "Hello World!" to the web page:
document.write("Hello World!");
JavaScript Variables
Variables are "containers" for storing information. Rules for JavaScript variable names:
    Variable names are case sensitive (y and Y are two different variables)
    Variable names must begin with a letter or the underscore character
Note: Because JavaScript is case-sensitive, variable names are case-sensitive.
JavaScript Operators
JavaScript Arithmetic Operators
Arithmetic operators are used to perform arithmetic between variables and/or values. Following
table lists arithmetic operators available in JavaScript:
            Operator       Description
            +              Addition
            -              Subtraction
            *              Multiplication
            /              Division
            %              Modulus (division remainder)
            ++             Increment
            --             Decrement
JavaScript Assignment Operators
Assignment operators are used to assign values to JavaScript variables. Following table lists
assignment operators:
Logical Operators
Logical operators are used to determine the logic between variables or values. Given that x=6 and y=3, the table b
Conditional Operator
JavaScript also contains a conditional operator that assigns a value to a variable based on some
condition.
Syntax
variablename= (condition)?value1:value2
Example
greeting=(visitor=="PRES")?"Dear President ":"Dear ";
If the variable visitor has the value of "PRES", then the variable greeting will be assigned the
value "Dear President " else it will be assigned "Dear".
    executed
    switch statement - use this statement to select one of many blocks of code to be executed
If Statement
Use the if statement to execute some code only if a specified condition is true.
Syntax:
if (condition)
 {
  code to be executed if condition is true
  }
Example:
<HTML>
     <BODY>
          <SCRIPT TYPE="text/javascript">
            var d = new Date();
            var time = d.getHours();
            if (time > 10)
            {
               document.write("<b>Good morning</b>");
           }
           </SCRIPT>
           <P>This example demonstrates the If statement.</P>
           <P>If the time on your browser is less than 10, you will get a "Good morning"
            greeting.</P>
    </BODY>
</HTML>
Example:
<HTML>
     <BODY>
              <SCRIPT TYPE="text/javascript">
              var d = new Date();
              var time = d.getHours();
              if (time<10)
              {
                  document.write("<b>Good morning</b>");
              }
            else if (time>=10 && time<16)
            {
                 document.write("<b>Good day</b>");
            }
          else
           {
                 document.write("<b>Hello World!</b>");
          }
         </SCRIPT>
         <P>
         This example demonstrates the if..else if...else statement.
         </P>
     </BODY>
</HTML>
The result is shown below:
Example:
<HTML>
     <BODY>
          <SCRIPT TYPE="text/javascript">
          var d=new Date();
          var theDay=d.getDay();
          switch (theDay)
           {
                  case 5:
                      document.write("<b>Finally Friday</b>");
                           break;
                     case 6:
                          document.write("<b>Super Saturday</b>");
                          break;
case 0:
document.write("<b>Sleepy Sunday</b>"); break;
default:
document.write("<b>I'm really looking forward to this
weekend!</b>");
}
</SCRIPT>
<P>This JavaScript will generate a different greeting based on what day it is. Note that Sunday=0, Monday=1, Tue
</BODY>
</HTML>
Alert Box
An alert box is often used if you want to make sure information comes through to the user.
When an alert box pops up, the user will have to click "OK" to proceed.
Syntax
alert("sometext");
Example:
<HTML>
<HEAD>
<SCRIPT TYPE="text/javascript"> function show_alert()
{
alert("Hello! I am an alert box!");
}
</SCRIPT>
</HEAD>
<BODY>
</BODY>
</HTML>
Confirm Box
    A confirm box is often used if you want the user to verify or accept something.
When a confirm box pops up, the user will have to click either "OK" or "Cancel" to proceed.
If the user clicks "OK", the box returns true. If the user clicks "Cancel", the box returns false.
Syntax:
confirm("sometext");
Example:
<HTML>
<HEAD>
<SCRIPT TYPE="text/javascript">
function show_confirm()
{
var r=confirm("Press a button!"); if (r==true)
{
alert("You pressed OK!");
}
else
{
alert("You pressed Cancel!");
}
}
</SCRIPT>
</HEAD>
<BODY>
<INPUT TYPE="button" onclick="show_confirm()" VALUE="Show a confirm box" />
</BODY>
</HTML>
Example:
<HTML>
           <HEAD>
                     <SCRIPT TYPE="text/javascript">
                              function show_prompt()
                               {
                                 var name=prompt("Please enter your name","Harry Potter");
                                 if (name!=null && name!="")
                                 {
                                    document.write("Hello " + name + "! How are you today?");
                                 }
                             }
                      </SCRIPT>
         </HEAD>
         <BODY>
            <INPUT TYPE="button" onclick="show_prompt()" value="Show prompt box" />
       </BODY>
</HTML>
JavaScript Functions
To keep the browser from executing a script when the page loads, you can put your script into a function. A functio
The parameters var1, var2, etc. are variables or values passed into the function. The {and the} defines the start and
Example:
<HTML>
          <HEAD>
                 <SCRIPT TYPE="text/javascript">
                          function displaymessage()
                           {
                             alert("Hello World!");
                           }
                  </SCRIPT>
          </HEAD>
       <BODY>
       <FORM>
           <INPUT TYPE="button" VALUE="Click me!" ONCLICK="displaymessage()"/>
       </FORM>
       </BODY>
</HTML>
JavaScript Loops
       Often when you write code, you want the same block of code to run over and over again in
a row. Instead of adding several almost equal lines in a script we can use loops to perform a task
like this.
       Loops execute a block of code a specified number of times, or while a specified condition
is true. In JavaScript, there are two different kinds of loops:
      for - loops through a block of code a specified number of times
      while - loops through a block of code while a specified condition is true
The for Loop
The for loop is used when you know in advance how many times the script should run.
Syntax
 for (variable=startvalue;variable<=endvalue;variable=variable+increment)
 {
 code to be executed
 }
 Example
 The example below defines a loop that starts with i=0. The loop will continue to run as long as i is less than
 <HTML>
 <BODY>
 <SCRIPT TYPE="text/javascript"> for (i = 0; i <= 5; i++)
 {
 document.write("The number is " + i); document.write("<br />");
 }
 </SCRIPT>
 <P>Explanation:</P>
 <P>This for loop starts with i=0.</P>
 <P>As long as <B>i</B> is less than, or equal to 5, the loop will continue to run.</P>
 <P><B>i</B> will increase by 1 each time the loop runs.</P>
 </BODY>
 </HTML>
Example:
      The example below defines a loop that starts with i=0. The loop will continue to run as long
as i is less than, or equal to 5. i will increase by 1 each time the loop runs:
<HTML>
    <BODY>
         <SCRIPT TYPE="text/javascript">
         i=0;
         while (i<=5)
         {
                       document.write("The number is " + i);
                       document.write("<br />");
                       i++;
          }
          </SCRIPT>
     </BODY>
</HTML>
Result:
Result:
Example:
<HTML>
<BODY>
<SCRIPT TYPE="text/javascript"> var i=0;
for (i=0;i<=10;i++)
{
if (i==3)
{
break;
}
document.write("The number is " + i); document.write("<br />");
}
</SCRIPT>
<P>Explanation: The loop will break when i=3.</P>
</BODY>
</HTML>
Result:
The continue Statement
The continue statement will break the current loop and continue with the next value.
Example:
<HTML>
<BODY>
<SCRIPT TYPE="text/javascript"> var i=0
for (i=0;i<=10;i++)
{
if (i==3)
{
continue;
}
document.write("The number is " + i); document.write("<br />");
}
</SCRIPT>
</BODY>
</HTML>
Result:
Client-Side Programming in JavaScript
Using JavaScript and forms
     FORM NAME="myform" defines and names the form. Elsewhere in the JavaScript
      you can reference this form by the name myform. The name you give your form is up to
      you, but it should comply with JavaScript's standard variable/function naming rules (no
      spaces, no weird characters except the underscore, etc.).
  ACTION="" defines how you want the browser to handle the form when it is submitted
      to a CGI program running on the server. As this example is not designed to submit
      anything, the URL for the CGI program is omitted.
  METHOD="GET" defines the method data is passed to the server when the form is
      submitted. In this case the attribute is puffer as the example form does not submit
      anything.
  INPUT TYPE="text" defines the text box object. This is standard HTML markup.
  INPUT TYPE="button" defines the button object. This is standard HTML markup
      except for the onClick handler.
  onClick="testResults(this.form)" is an event handler -- it handles an event, in this case
      clicking the button. When the button is clicked, JavaScript executes the expression within
      the quotes. The expression says to call the testResults function elsewhere on the page,
      and pass to it the current form object.
Getting a value from a form object
Here's the full script you can try as you experiment with obtaining values from form objects. Load the page
<HTML>
<HEAD>
<TITLE>Test Input</TITLE>
<SCRIPT LANGUAGE="JavaScript">
function testResults (form) {
var TestVar = form.inputbox.value; alert ("You typed: " + TestVar);
}
</SCRIPT>
</HEAD>
<BODY>
<FORM NAME="myform" ACTION="" METHOD="GET">Enter something inthe box: <BR>
       <INPUT TYPE="text" NAME="inputbox" VALUE=""><P>
       <INPUT             TYPE="button"    NAME="button"                               Value="Click"
     onClick="testResults(this.form)">
       </FORM>
       </BODY>
</HTML>
      Here's how the script works. JavaScript calls the testResults function when you click the
button in the form. The testResults function is passed to the form object using the
syntax this.form (the this keyword references the button control; form is a property of the button
control and represents the form object). I've given the form object the name form inside the
testResult function, but you can any name you like.
      The testResults function is simple -- it merely copies the contents of the text box to a
variable named TestVar. Notice how the text box contents were referenced. I defined the form
object I wanted to use (called form), the object within the form that I wanted (called inputbox),
and the property of that object I wanted (the value property).
Setting a value in a form object
      The value property of the input box, shown in the above example, is both readable and
writable. That is, you can read whatever is typed into the box, and you can write data back into
it. The process of setting the value in a form object is just the reverse of reading it. Here's a short
example to demonstrate setting a value in a form text box. The process is similar to the previous
example, except this time there are two buttons. Click the "Read" button and the script reads
what you typed into the text box. Click the "Write" button and the script writes a particularly
lurid phrase into the text box.
set_formval.html
<HTML>
         <HEAD>
            <TITLE>Test Input </TITLE>
            <SCRIPT LANGUAGE="JavaScript">
                function readText (form) {
                   TestVar =form.inputbox.value;
                   alert ("You typed: " + TestVar);
                }
      When you click the "Read" button, JavaScript calls the readText function, which reads
       and displays the value you entered into the text box.
      When you click the "Write" button, JavaScript calls the writeText function, which
       writes "Have a nice day!" in the text box.
Reading other form object values
      The text box is perhaps the most common form object you'll read (or write) using
JavaScript. However, you can use JavaScript to read and write values from most other objects
(note that JavaScript cannot currently be used to read or write data using the password text box).
In addition to text boxes, JavaScript can be used with:
       Hidden text box (TYPE="hidden").
       Radio button (TYPE="radio")
       Check box (TYPE="checkbox")
       Text area (<TEXT AREA>)
       Lists (<SELECT>)
      Following is an example of testing which button is selected. The for loop in the testButton
function cycles through all of the buttons in the "rad" group. When it finds the button that's
selected, it breaks out of the loop and displays the button number (remember: starting from 0).
form_radio.html
 <HTML>
       <HEAD>
           <TITLE>Radio Button Test</TITLE>
                <SCRIPT LANGUAGE="JavaScript">
                function testButton (form){
                   for (Count = 0; Count < 3; Count++)
                      { if (form.rad[Count].checked)
                         break;
                      }
                      alert ("Button " + Count + " is selected");
                  }
                </SCRIPT>
       </HEAD>
       <FORM NAME="testform">
       <INPUT TYPE="button" NAME="button" Value="Click"
         onClick="testButton(this.form)"> <BR>
       <INPUT TYPE="radio" NAME="rad" Value="rad_button1" onClick=0><BR>
       <INPUT TYPE="radio" NAME="rad" Value="rad_button2" onClick=0><BR>
       <INPUT TYPE="radio" NAME="rad" Value="rad_button3" onClick=0><BR>
       </FORM>
 </HTML>
Result:
      Setting a radio button selection with HTML is simple. If you want the form to initially
appear with a given radio button selected, add the CHECKED attribute to the HTML markup for
that button:
<INPUT TYPE="radio" NAME="rad" Value="rad_button1" CHECKED onClick=0>
You can also set the button selection programmatically with JavaScript, using the checked property. Specify the in
Result:
As with the radio button object, add a CHECKED attribute to the HTML markup for that check box you wish t
     You can also set the button selection programmatically with JavaScript, using the checked
property. Specify the name of the checkbox you want to check, as in
form.check1.checked = true;
     You can use JavaScript to read the contents of the text area box. This is done with the value
property. Here is an example:
form_textarea.html
<HTML>
          <HEAD>
          <TITLE>Text Area Test</TITLE>
          <SCRIPT LANGUAGE="JavaScript">
        function seeTextArea (form)
          { alert (form.myarea.value);
        }
        </SCRIPT>
        </HEAD>
        <BODY>
<FORM NAME="myform">
                  <INPUT TYPE="button" NAME="button3" Value="Test"
                   onClick="seeTextArea(this.form)">
                  <TEXTAREA NAME="myarea" COLS="40" ROWS="5">
                  </TEXTAREA>
                  </FORM>
        </BODY>
</HTML>
Result:
      You can preload text into the text area in either of two ways. One method is to enclose text
between the <TEXTAREA> and </TEXTAREA> tags. This method is useful if you wish to
include hard returns, as these are retained in the text area box. Or, you can set it
programmatically with JavaScript using the following syntax:
 Result:
If you want the text of the selected list item instead of the index, use this in the testSelect function:
Using onSubmit
      Here's an example of using the onSubmit event handler to send mail. The onSubmit event
handler tells JavaScript what to do when the user clicks the Submit button: call the mailMe()
function, where additional mail fields are appended to a mailto: URL. Navigator automatically
opens a new mail window with the fields filled in. Write the body of the message, and send the
mail off to the recipient.
onsubmit.html
<HTML>
          <HEAD>
          <TITLE>onSubmit Test</TITLE>
          <SCRIPT LANGUAGE="JavaScript">
          function mailMe(form){
             Subject=document.testform.inputbox1.value;
             CC= document.testform.inputbox2.value;
             BCC= document.testform.inputbox3.value;
             location = "mailto:[email protected]?subject="+Subject+"&Bcc="+
             BCC+"&cc="+CC;
             return true;
          }
          </SCRIPT>
          </HEAD>
<BODY>
<FORM NAME="testform" onSubmit="return mailMe(this.form)" >Subject of message: <BR>
<INPUT TYPE="text" NAME="inputbox1" VALUE="This is such a great form!" SIZE=50>
<P>Send cc to: <BR>
<INPUT TYPE="text" NAME="inputbox2" VALUE="" SIZE=50><P>
Send blind cc to: <BR>
<INPUT TYPE="text" NAME="inputbox3" VALUE="" SIZE=50><P>
<INPUT TYPE="submit"><BR>
</FORM>
</BODY>
</HTML>
Using submit
       In the next example the submit method is used instead. The script is little changed, except
that the onSubmit handler is removed, and an onClick hander for a renamed form button is added
in its place. The submit() method replaces the return true statement in the previous example.
submit.html
<HTML>
           <HEAD>
           <TITLE>test</TITLE>
           <SCRIPT LANGUAGE="JavaScript">
           function mailMe(form){
               Subject=document.testform.inputbox1.value
               CC= document.testform.inputbox2.value
               BCC= document.testform.inputbox3.value
               location                         =                            "/javaworld/cgi-bin/jw-
         [email protected]?subject="+Subject+"&Bcc="+
               BCC+"&cc="+CC
               document.testform.submit();
           }
           </SCRIPT>
           </HEAD>
<BODY>
<FORM NAME="testform">
Subject of message: <BR>
<INPUT TYPE="text" NAME="inputbox1" VALUE="This is such a great form!"
SIZE=50><P>
Send cc to: <BR><INPUT TYPE="text" NAME="inputbox2" VALUE="" SIZE=50><P>
Send blind cc to: <BR><INPUT TYPE="text" NAME="inputbox3" VALUE="" SIZE=50><P>
<INPUT TYPE="button" VALUE="Send Mail" onClick="mailMe()"><BR>
</FORM>
</BODY>
</HTML>
Server-Side Programming in JavaScript
What is Server-side Scripting?
       Normally when a browser requests an HTML file, the server returns the file, but if the file
contains a server-side script, the script inside the HTML file is executed by the server before the
file is returned to the browser as plain HTML.
Server-side JavaScript (SSJS) refers to JavaScript that runs on server-side and is therefore not
downloaded to the browser. This term is used to differentiate it from regular JavaScript, which is
predominantly used on the client-side (also referred to as client-side JavaScript or CSJS for
short). The first implementation of SSJS was Netscape's LiveWire, which was included in their
Enterprise Server 2.0 back in 1996. Since then, a number of other companies have followed suit
in offering an alternative to the usual server-side technologies. One of the biggest players in the
field was Microsoft. They supported the use of JavaScript on the server within what is now
known as "classic" ASP. Along with the most common VBScript language, it also supported
JavaScript and PerlScript. In reality, Microsoft utilized JScript, their own version of JavaScript.
To use JScript/JavaScript, all you had to do was set the LANGUAGE attribute in the opening
script tag:
<%@LANGUAGE="JavaScript"%>
<%
Response.Write("<HTML>\r")
Response.Write("<FONT COLOR=\"red\">\"Hello World\"</FONT><BR>\r") Response.Write("</HTML>\
r")
%>
      Since the code runs on the server, what is sent to the client is the output of the script rather
than the source code. Hence only the tags produced by the Response.Write() functions are found
in the page source:
<HTML>
<FONT COLOR="red">"Hello World"</FONT><BR>
</HTML>
      In addition to alleviating development complexity, server-side JavaScript offers a few other
benefits that you may not have considered:
      The same code can validate data on both the client (for immediate user feedback) and on
       the server (for security), so validations never get out of sync.
      The same code can prepare both the HTML DOM server side and modify it client-side,
       when the user changes the data or it's refreshed from the server.
      Using the same code on both the client and the server, developers have fewer
       technologies to learn and stay on top of, and fewer parts of the application or site to
       maintain.
       On the server, you also embed JavaScript in HTML pages. The server-side statements can
connect to relational databases from different vendors, share information across users of an
application, access the file system on the server, or communicate with other applications through
LiveConnect and Java. HTML pages with server-side JavaScript can also include client-side
JavaScript.
      In contrast to pure client-side JavaScript pages, HTML pages that use server-side JavaScript
are compiled into bytecode executable files. These application executables are run by a web
server that contains the JavaScript runtime engine. For this reason, creating JavaScript
applications is a two-stage process.
     In the first stage, shown in Figure, you create HTML pages (which can contain both client-
side and server-side JavaScript statements) and JavaScript files. You then compile all of those
files into a single executable.
Working Example:
<SCRIPT TYPE='text/javascript'>
function notEmpty(elem, helperMsg){
       if(elem.value.length == 0){
               alert(helperMsg);
               elem.focus();
               return false;
       }
       return true;
}
Result:
Result:
Result:
       }
                                 World Institute Of Technology
              8km milestone ,Sohna Palwal Road , NH-71 B ,Sohna , Gurgaon ,Haryana.
               Website : www.wit.net.in                    E-mail : [email protected]
return true;
       return false;
}
      The first part of this function is where we create easy references to our HTML inputs using
the getElementById function. These quick references will make our next block of code much
easier to read!
XML Basics
What is XML?
   XML stands for EXtensible Markup Language
   XML is a markup language much like HTML
   XML was designed to carry data, not to display data
   XML tags are not predefined. You must define your own tags
   XML is designed to be self-descriptive
   XML is a W3C Recommendation
     The root element in the example is <bookstore>. All <book> elements in the document are
contained within <bookstore>. The <book> element has 4 children: <title>,< author>, <year>,
<price>.
  <note date="12/11/2007">
  <to>Tove</to>
  <from>Jani</from>
  </note>
       The error in the first document is that the date attribute in the note element is not quoted.
  Entity References
       Some characters have a special meaning in XML. If you place a character like "<" inside an
  XML element, it will generate an error because the parser interprets it as the start of a new
  element. This will generate an XML error:
  <message>if salary < 1000 then</message>
  To avoid this error, replace the "<" character with an entity reference:
<message>if salary < 1000 then</message> There
Comments in XML
The syntax for writing comments in XML is similar to that of HTML.
<!-- This is a comment -->
XML Elements
An XML element is everything from (including) the element's start tag to (including) the
element's end tag.
An element can contain:
    other elements
    text
    attributes
    or a mix of all of the above...
<bookstore>
 <book category="CHILDREN">
 <title>Harry Potter</title>
 <author>J K. Rowling</author>
 <year>2005</year>
 <price>29.99</price>
 </book>
 <book category="WEB">
 <title>Learning XML</title>
 <author>Erik T. Ray</author>
 <year>2003</year>
 <price>39.95</price>
 </book>
</bookstore>
      In the example above, <bookstore> and <book> have element contents, because they
contain other elements. <book> also has an attribute (category="CHILDREN"). <title>,
<author>, <year>, and <price> have text content because they contain text.
                                    World Institute Of Technology
              8km milestone ,Sohna Palwal Road , NH-71 B ,Sohna , Gurgaon ,Haryana.
                  Website : www.wit.net.in                  E-mail : [email protected]
XML Naming Rules
XML elements must follow these naming rules:
    Names can contain letters, numbers, and other characters
    Names cannot start with a number or punctuation character
    Names cannot start with the letters xml (or XML, or Xml, etc)
    Names cannot contain spaces
Any name can be used, no words are reserved.
XML Attributes
In HTML, attributes provide additional information about elements:
<img src="computer.gif">
<a href="demo.asp">
       Attributes often provide information that is not a part of the data. In the example below, the
file type is irrelevant to the data, but can be important to the software that wants to manipulate
the element:
<file type="gif">computer.gif</file>
Your browser formed a connection to a Web server, requested a page and received it.
Behind the Scenes
     If you want to get into a bit more detail on the process of getting a Web page onto your
computer screen, here are the basic steps that occurred behind the scenes:
    The browser broke the URL into three parts:
          1. The protocol ("http")
          2. The server name ("www.howstuffworks.com")
          3. The file name ("web-server.htm")
    The browser communicated with a name server to translate the server name
       "www.howstuffworks.com" into an IP Address, which it uses to connect to the server
       machine.
    The browser then formed a connection to the server at that IP address on port 80.
Note: Any server machine makes its services available to the Internet using numbered ports,
one for each service that is available on the server. For example, if a server machine is
running a Web server and an FTP server, the Web server would typically be available on port
Encryption
There's a whole lot of information that we don't want other people to see, such as:
   Credit-card information
   Social Security numbers
                                  World Institute Of Technology
               8km milestone ,Sohna Palwal Road , NH-71 B ,Sohna , Gurgaon ,Haryana.
                Website : www.wit.net.in                    E-mail : [email protected]
      Private correspondence
      Personal details
      Sensitive company information
      Bank-account information
       Encryption is the conversion of data into a form, called a ciphertext, that cannot be easily
understood by unauthorized people. Decryption is the process of converting encrypted data back
into its original form, so it can be understood.
       The use of encryption/decryption is as old as the art of communication. In wartime,
a cipher, often incorrectly called a code, can be employed to keep the enemy from obtaining the
contents of transmissions. (Technically, a code is a means of representing a signal without the
intent of keeping it secret; examples are Morse code and ASCII.) Simple ciphers include the
substitution of letters for numbers, the rotation of letters in the alphabet, and the "scrambling" of
voice signals by inverting the sideband frequencies. More complex ciphers work according to
sophisticated computer algorithms that rearrange the data bits in digital signals.
       In order to easily recover the contents of an encrypted signal, the correct decryption key is
required. The key is an algorithm that undoes the work of the encryption algorithm.
Alternatively, a computer can be used in an attempt to break the cipher. The more complex the
encryption algorithm, the more difficult it becomes to eavesdrop on the communications without
access to the key.
       Encryption/decryption is especially important in wireless communications. This is because
wireless circuits are easier to tap than their hard-wired counterparts. Nevertheless,
encryption/decryption is a good idea when carrying out any kind of sensitive transaction, such as
a credit-card purchase online, or the discussion of a company secret between different
departments in the organization. The stronger the cipher -- that is, the harder it is for
unauthorized people to break it -- the better, in general. However, as the strength of
encryption/decryption increases, so does the cost.
       In recent years, a controversy has arisen over so-called strong encryption. This refers to
ciphers that are essentially unbreakable without the decryption keys. While most companies and
their customers view it as a means of keeping secrets and minimizing fraud, some governments
view strong encryption as a potential vehicle by which terrorists might evade authorities. These
governments, including that of the United States, want to set up a key-escrow arrangement. This
means everyone who uses a cipher would be required to provide the government with a copy of
the key. Decryption keys would be stored in a supposedly secure place, used only by authorities,
and used only if backed up by a court order. Opponents of this scheme argue that criminals could
hack into the key-escrow database and illegally obtain, steal, or alter the keys. Supporters claim
that while this is a possibility, implementing the key escrow scheme would be better than doing
nothing to prevent criminals from freely using encryption/decryption.
Caesar's Cipher
      Julius Caesar also used a similar substitution technique, shifting three letters up. If he
wanted to say "CROSSING THE RUBICON," for instance, he'd write down "FURVV LQJWK
HUXEL FRQ" instead. As you can see, the text is also broken up into even groups in order to
make the size of each word less obvious.
      Think of it like this: You create a coded message to send to a friend in which each letter is
substituted with the letter that is two down from it in the alphabet. So "A" becomes "C," and "B"
becomes "D". You have already told a trusted friend that the code is "Shift by 2". Your friend
gets the message and decodes it. Anyone else who sees the message will see only nonsense.
The same goes for computers, but, of course, the keys are usually much longer.
Hashing Algorithm
      The key in public-key encryption is based on a hash value. This is a value that is computed
from a base input number using a hashing algorithm. Essentially, the hash value is a summary of
the original value. The important thing about a hash value is that it is nearly impossible to derive
the original input number without knowing the data used to create the hash value. Here's a simple
example:
                   Input number       Hashing algorithm          Hash value
                   10,667              Input # x 143               1,525,381
      You can see how hard it would be to determine that the value 1,525,381 came from the
multiplication of 10,667 and 143. But if you knew that the multiplier was 143, then it would be
very easy to calculate the value 10,667. Public-key encryption is actually much more complex
than this example, but that's the basic idea.
      Public keys generally use complex algorithms and very large hash values for encrypting,
including 40-bit or even 128-bit numbers. A 128-bit number has a possible 2 128, or
3,402,823,669,209,384,634,633,746,074,300,000,000,000,000,000,000,000,000,000,000,000,000
different combinations -- this would be like trying to find one particular grain of sand in the
Sahara Desert.
Digital Signature
      A digital signature (not to be confused with a digital certificate) is an electronic signature
that can be used to authenticate the identity of the sender of a message or the signer of a
document, and possibly to ensure that the original content of the message or document that has
been sent is unchanged. Digital signatures are easily transportable, cannot be imitated by
someone else, and can be automatically time-stamped. The ability to ensure that the original
signed message arrived means that the sender cannot easily repudiate it later.
      A digital signature can be used with any kind of message, whether it is encrypted or not,
simply so that the receiver can be sure of the sender's identity and that the message arrived intact.
A digital certificate contains the digital signature of the certificate-issuing authority so that
anyone can verify that the certificate is real.
How It Works
      Assume you were going to send the draft of a contract to your lawyer in another town. You
want to give your lawyer the assurance that it was unchanged from what you sent and that it is
really from you.
    1. You copy-and-paste the contract (it's a short one!) into an e-mail note.
    2. Using special software, you obtain a message hash (mathematical summary) of the
         contract.
    3. You then use a private key that you have previously obtained from a public-private key
         authority to encrypt the hash.
    4. The encrypted hash becomes your digital signature of the message. (Note that it will be
         different each time you send a message.)
At the other end, your lawyer receives the message.
    1. To make sure it's intact and from you, your lawyer makes a hash of the received message.
    2. Your lawyer then uses your public key to decrypt the message hash or summary.
    3. If the hashes match, the received message is valid.
Firewalls
     A firewall is a part of a computer system or network that is designed to block unauthorized
access while permitting authorized communications. It is a device or set of devices that is
configured to permit or deny network transmissions based upon a set of rules and other criteria.
     Firewalls can be implemented in either hardware or software, or a combination of both.
Firewalls are frequently used to prevent unauthorized Internet users from accessing private
networks connected to the Internet, especially intranets. All messages entering or leaving the
Types of Firewalls
There are two main types of firewalls:
     Network firewalls and
     Host-based firewalls.
Network firewalls, such as the software-based Microsoft’s Internet Security and Acceleration
(ISA) Server or the hardware-based Nortel Networks Alteon Switched Firewall System, protect
the perimeter of a network by watching traffic that enters and leaves.
Host-based firewalls, such as Internet Connection Firewall (ICF—included with Windows XP
and Windows Server 2003), protect an individual computer regardless of the network it’s
connected to. You might need one or the other—but most businesses require a combination of
both to meet their security requirements.