TCP IP Vulnerabilities
TCP IP Vulnerabilities
TCP IP Vulnerabilities
Submitted by
Rudhrakumar Venkatesan venkatru@ece.orst.edu
Shashidhar Lakkavalli lakkavsh@ece.orst.edu
Abstract
TCP/IP is a set of protocols developed to allow cooperating computers to share resources
across a network. The TCP/IP protocol suite, which is very widely used today, has a large
number of serious security flaws inherent in the protocols, regardless of the correctness of any
implementations. We describe a variety of attacks based on these flaws.
The Attack methods in TCP/IP Networks, which we will be trying to explore in this
paper, are
(i)
Sniffing - A Passive attack using Sniffer Programs those trap the packets.
(ii)
(iii)
(iv)
impact on the network. We also explore the various methods of detection, prevention and
recovery from such attacks.
Contents
1 Introduction
1.1 TCP/IP
1.2 Attacks
2 Passive Attacks
2.1 Sniffing
2.1.1 Protocols Vulnerable to Sniffing
2.1.2 Methods for sniffing
2.1.3 Prevention of Vulnerabilities
2.1.4 Encryption Tools
2.1.5 Sniffing Programs
3 Active Attacks
3.1 Spoofing & Hijacking
3.1.1 IP Spoofing
3.1.2 Hijacking
3.1.3 How Its Done
3.1.3.1
Connection Killing
3.1.3.2
Connection Hijacking
3.1.4 Impact
3.1.5 Solutions
3.2 Sequence Number Guessing
3.2.1 Details Of Attack
3.2.2 Solutions
3.3 Denial Of Service
3.3.1 Some Basic Targets for an Attack
3.3.2 The Attacks
3.3.3 Protecting a system against DOS Attack
4 Conclusion
5 Reference
1 Introduction
The TCP/IP protocol suite is the most widely used communication standard on the
Internet. Despite that, there are a number of serious security flaws inherent in the protocols.
Flaws even arise due to the bad implementation and improper configuration of the Applications
using these protocol suites. The attacks are classified into Active attacks and passive attacks
depending on the behaviour of the attacker. Sniffing is the most common form of passive attack
and so we will be discussing about it in detail, where as there are many prominent forms of
active attacks and we will be considering spoofing, hijacking, sequence number prediction and
Denail of service attacks into discussion.
1.1 TCP/IP
TCP provides a full duplex reliable stream connection between two end points. A
connection is uniquely defined by the quadruple (IP address of sender, TCP port number of the
sender, IP address of the receiver, TCP port number of the receiver). Every byte that is sent by a
host is marked with a sequence number (32 bits integer) and is acknowledged by the receiver
using this sequence number. The sequence number for the first byte sent is computed during the
connection opening. It changes for any new connection based on rules designed to avoid reuse of
the same sequence number for two different sessions of a TCP connection.
1.2 Attacks
In security, the word attack has taken on very specific connotations. For example, you
might here of researchers trying to "attack a cryptosystem". The word is often used in the
abstract sense rather than in any physical sense. This academic circles, this word is often used in
preference to other synonyms such as crack or break.
A passive attack (like sniffer)is one that can take place by eavedropping. An active
attack(Like Hijacking) is one that requires interaction, such as injecting something into the data
stream or change, delete, reroute, add, forge or divert data. All attacks are divided into these two
categories.
2. Passive Attacks
2.1 Sniffing
Packet sniffing is the act of intercepting and reading any or all network traffic that is
being transmitted across a shared network communication channel. Sniffing programs are of 2
two forms. Commercial packet sniffers are used to help maintain networks. Underground packet
sniffers are used to break into computers.
5. To detect a sniffing device that only collects data and does not respond to any of the
information, requires physically checking all your ethernet connections by walking around
and checking the ethernet connections individually.
6. Active hubs send to each system only packets intended for it rendering promiscuous sniffing.
7. Using interfaces that will not allow processes to run in promiscuous mode and thus prevent
sniffing.
2.1.4 Encryption Tools
Deslogin
SwIPe
Netlock
Kerberos
One time password techniques
2.1.5 Tools to detect packet sniffers
Antisniff
Check Promiscuous Mode
Neped
Sentinet
2.1.6 Sniffing programs
Ethereal
Network Associates Sniffer
BlackICE Pro
CiAll
Tcpdump(Unix)
3. Active Attacks
3.1 Spoofing & Hijacking
Passive attacks using sniffers are becoming more and more frequent on the Internet. The
attacker obtains a user id and password that allows him to logon as
that user. In order to prevent such attacks people have been using identification schemes such as
one-time password [SKEY] or ticketing identification [Kerberos]. Though they prevent password
sniffing on an unsecure network these methods are still vulnerable to an active attack as long as
they neither encrypt nor sign the data stream. Still many people are complacent believing that
active attacks are very difficult and hence a lesser risk. But we can implement a IP hijack and
successfully spoof the system with an active attack which can be done with
the same resources as for a passive sniffing attack.
3.1.1 IP spoofing
To gain access, intruders create packets with spoofed source IP addresses. This exploits
applications that use authentication based on IP addresses and leads to unauthorized user and
possibly root access on the targeted system. It is possible to route packets through filtering-router
firewalls if they are not configured to filter incoming packets whose source address is in the local
domain. It is possible to spoof even if no reply packets can reach the attacker. Examples of
configurations that are potentially vulnerable include - routers to external networks that support
multiple internal interfaces - routers with two interfaces that support subnetting on the internal
network - proxy firewalls where the proxy applications use the source IP address for
authentication.
3.1.2 Hijacking
Once the intruders have root access on a system, they can hijack existing terminal and
login connections from any user on the system. In taking over the existing connections, intruders
can bypass one-time passwords and other strong authentication schemes by tapping the
connection after the authentication is complete. For example, a legitimate user connects to a
remote site through a login or terminal session; the intruder hijacks the connection after the user
has completed the authentication to the remote location; the remote site is now compromised.
Spoofing is classified into
Non-blind spoofing Using the spoofing to interfer with a connection that sends packets along
your subnet.
Blind spoofing Using the spoofing to interfer with a connection (or creating one), that does not
send packets along your cable.
The concept of non-blind spoofing(NBS) is pretty simple. Because packets travel within
your reach, you can get the current sequence and acknowledge (SEQ/ACK) numbers on the
connection. NBS is thus a very easy and accurate method of attack, but limited to connections
going over your subnet. In spoofing documentation these attacks are sometimes ommited,
because they are mostly 'denial-of-service' attacks, or because people don't realise the advantage
a spoof (in particulary a hijack) can have above simple password sniffing. Spoofing in generally
is refered to as a verry high level of attack. This refers to blind spoofing (BlS).
3.1.3 How It's Done
3.1.3.1 Connection Killing
Setup
host A <------X------------------------->host B | A,B have a TCP connection running
host S <------/ A,S on same subnet
3.1.4. Impact
Current intruder activity in spoofing source IP addresses can lead to unauthorized remote
root access to systems behind a filtering-router firewall. After gaining root access and taking
over existing terminal and login connections, intruders can gain access to remote hosts.
3.1.5 Solutions
A. Detection
IP spoofing
1. If you monitor packets using network-monitoring software such as netlog, look for a packet
on your external interface that has both its source and destination IP addresses in your local
domain. If you find one, you are currently under attack.
2. Another way to detect IP spoofing is to compare the process accounting logs between
systems on your internal network. If the IP spoofing attack has succeeded on one of your
systems, you may get a log entry on the victim machine showing a remote access; on the
apparent source machine, there will be no corresponding entry for initiating that remote
access.
Hijacking
1. When the intruder attaches to an existing terminal or login connection, users may detect
unusual activity, such as commands appearing on their terminal that they did not type or a
blank window that will no longer respond to their commands. Encourage your users to
inform you of any such activity.
2. In addition, pay particular attention to connections that have been idle for a long time. Once
the attack is completed, it is difficult to detect. However, the intruders may leave remnants of
their tools. For example, you may find a kernel streams module designed to tap into existing
TCP connections.
B. Prevention
IP spoofing
The best method of preventing the IP spoofing problem is to install a filtering router that
restricts the input to your external interface (known as an input filter) by not allowing a packet
through if it has a source address from your internal network. In addition, you should filter
outgoing packets that have a source address different from your internal network in order to
prevent a source IP spoofing attack originating from your site. If your vendor's router does not
support filtering on the inbound side of the interface or if there will be a delay in incorporating
the feature into your system, you may filter the spoofed IP packets by using a second router
between your external interface and your outside connection. Configure this router to block, on
the outgoing interface connected to your original router, all packets that have a source address in
your internal network. For this purpose, you can use a filtering router or a UNIX system with
two interfaces that supports packet filtering. Disabling source routing at the router does not
protect you from this attack, but it is still good security practice to do so.
Hijacking
There is no specific way to prevent users from hijacking other than preventing intruders
from gaining root access in the first place. If you have experienced a root compromise, you have
to do a recovery.
If X had guessed the sequence number right B's server thinks it has a legitimate
connection with A, when in fact X is sending the packets. X can't see the output from this
session, but it can execute commands as more or less any user
There is a minor difficulty here. If A sees B's message, it will realize that B is
acknowledging something it never sent, and will send a RST packet in response to tear down the
connection.
3.2.2 Solution
The problem encountered above is because the attacker was able to guess the initial
sequence number. By having the initial sequence number a random number, the sequence attack
can be avoided. But, this leads to protocol problems like duplicate packets and reincarnations of
packets of the old connection at the server, due to which the server will not be able to distinguish
if the packets were from the current session or from the previous connection. One way to avoid
this is to allot sequence number space to each port, and the sequence numbers are incremented
according to the following relationship
ISN = M + F(localhost, localport, remotehost, remoteport).
It is important that F not be computable from the outside, or an attacker could still guess
at sequence numbers from the initial sequence number used for some other connection. If F is a
cryptographic hash function of the connection-id and some secret data, then it is a good source of
a unpredictable random number. Hash techniques like MD5 is a good choice, since the code is
widely available. The secret data can either be a true random number [10], or it can be the
combination of some per-host secret and the boot time of the machine. The boot time is included
to ensure that the secret is changed on occasion. Other data, such as the host's IP address and
name, may be included in the hash as well.
c. Kernel Tables
Overflow in the kernel tables will cause serious problems on the system. The kernel have a
kernelmap limit, if the system reach this limit it can not allocate more kernel memory and must
be rebooted. The kernel memory is not only used for RAM, CPU:s, screens and so on, it it also
used for ordinaries processes. Meaning that any system can be crashed and with a mean
algorithm pretty fast. In Solaris 2.X the amount of kernel memory the system is usingit is
measured and reported with the sar command , but for SunOS 4.X there is no such command. So
in SunOS 4.X we don't even can get a warning.
d. RAM
A denial of service attack that allocates a large amount of RAM can make a great deal of
problems. NFS and mail servers are actually extremely sensitive because they do not need much
RAM and therefore often don't have much RAM. An attack at a NFS server is trivial. The normal
NFS client will do a great deal of caching, but a NFS client can be anything including the
program you wrote yourself.
3.3.2 The Attacks
(A). Taking Advantage Of Finger
Most fingerd installations support redirections to an other host.
Ex: $finger @system.two.com@system.one.com
In this example the finger will go through system.one.com and on to system.two.com. As far as
system.two.com knows it is system.one.com who is fingering. So this method can be used for
hiding, but also for a very dirty denial of service attack.
Foe eg in :
$
finger
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@host.we.attack.
All those @ signs will get finger to finger host.we.attack again and again and again... The effect
on host.we.attack is powerful and the result is high bandwidth, short free memory and a hard
disk with less free space, due to all child processes.
The solution is to install a fingerd which don't support redirections, for example GNU finger.
(B). Freezing Up X-Windows
If a host accepts a telnet session to the X-Windows port, somewhere between 6000 and
6025(In most cases 6000) it could be used to freeze up the X-Windows system. This can be made
with multiple telnet connections to the port or with a program which sends multiple
XOpenDisplay() to the port. The same thing can happen to Motif or Open Windows. The
solution is to deny connections to the X-Windows port.
(C). Attacking With Lynx Clients
A World Wide Web server will fork an httpd process as a respond to a request from a
client, typical Netscape or Mosaic. The process lasts for less than one second and the load will
therefore never show up if someone uses ps. In most causes it is therefore very safe to launch a
denial of service attack that makes use of multiple WWW clients, typical lynx clients. But the
netstat command could be used to detect the attack. Some httpd:s (for example http-gw) will
have problems besides the normal high bandwidth, low memory. And the attack can in those
cases get the server to loop.
to that port. For each Operating System there is a standard default, which may be configurable by
the superuser.
(O). Crashing Systems With Ping Flooding
If someone can ping a machine from a Windows 95 machine, it is possible to reboot or
freeze your machine. The attacker simply writes: ping -l 65510 address.to.the.machine And the
machine will freeze or reboot. It even works for for kernel 2.0.7 up to version 2.0.20. and 2.1.1.
for Linux (crash). AIX4, OSF, HPUX 10.1, DUnix 4.0 (crash). OSF/1, 3.2C, Solaris 2.4 x86
(reboot).
(P). Malicious Use Of Subnet Mask Reply Message
The subnet mask reply message is used under the reboot, but some hosts are known to
accept the message any time without any check. If so all communication to or from the host us
turned off, it's dead. The host should not accept the message any time but under the reboot.
3.3.3 Protecting A System Against Denial Of Service Attacks
You can not make your system totally secured against denial of service, but the following
methods can reduce the risk.
(A). Security Patches
Always install the proper security patches. Also note that patches change over time and
that a solution suggested in security bulletins (i.e. CERT) often is somewhat temporary.
(B). Port Scanning
Check which services you have. Scan the ports with sprobe or some other port scanner.
You should do this regualy to see that anyone don't have installed a service that you don't want
on the system. Disable every service that you don't need, could for example be rexd, fingerd,
systat, netstat, rusersd, sprayd, pop3, uucpd, echo, chargen, tftp, exec, ufs, daytime, time. Any
combination of echo, time, daytime and chargen is possible to get to loop. There is however no
need to turn discard off. The discard service will just read a packet and discard it, so if you turn
off it you will get more sensitive to denial of service and not the opposite.
(C). Check For The Attacks
Check for the possible attacks. Perform a stress test your system with several services and
look at the effect.
(D). Extra Security Systems
The basic that you always should install is a logdaemon and a wrapper. A firewall could
also be very good, but expensive. Note that you should be very careful if building your own
firewall or you might open up new and very bad security holes, but it is a very easy if you have
some basic knowledge. It is also very good to replace services that you need, for example telnet,
rlogin, rsh or whatever, with a tool like ssh. Ssh is free and can be found on the web.
(E). Monitoring Security
Also monitor security regularly, for example through examining system log files, history
files. Even in a system without any extra security systems could several tools be found for
monitoring, for example: - uptime - showmount - ps - netstat - finger
4. Conclusion
In this paper, we considered the most common passive and active attacks possible on
TCP/IP protocol suite. Several attack methods, their impact, detection, prevention and solutions
were discussed. In the course of the discussion, we see that most of the vulnerabilities are due to
bad implementation and improper configuration of the network applications. The user can
employ the use of vulnerability detection and prevention tools to minimize the possibility of
attacks on user machines and applications. The IETF has considered the TCP/IP protocol suite
vulnerabilities and the upcoming versions of TCP and IP is expected to minimize them.
5. References
[1]. Security Problems in the TCP/IP Protocol Suite
Bellovin, Steven M.; 1989;
[2]. A Simple Active Attack Against TCP
Joncheray, Laurent; 1995;
[3]. IP Hijacking
Laurant Joucheray; April 24, 1995;
[4]. Sequence Number Attacks
Rik Farrow; December 1994 ;
[5]. A Weakness in the 4.2BSD Unix TCP/IP Software
Morris, Robert T; 1985;
[6]. Hacking Lexicon
http://www.robertgraham.com/pubs/hacking-dict.html
[7]. Some TCP/IP Vulnerabilities
http://staff.washington.edu/dittrich/talks/agora/
[8]. The Hawks security links
http://www.dbnet.ece.ntua.gr/~george/security/
[9]. INTRODUCTION TO DENIAL OF SERVICE
http://www.attrition.org/~modify/texts/denial_of_service/denial_of_service.txt
[10]. TCP/IP Security
http://www.security.promo.ru/english/block.html