To Be or Not To Be!!!

Just another weblog

Detection of Firewalls, and Probing networks behind firewalls.


This paper will discuss identification, detection and the penetration techniques of firewalls, more specifically; the ability to probe a network behind a firewall. The continued version will discuss the ability to have access to a key or target network behind a firewall, without having to disable/alter the firewall, and again a bit more specifically; port redirection techniques. It is recommended that you have knowledge of networking, the UNIX Operating system, and an nmap utility on hand ( Enjoy…and my apologies for the crappy format.

The Suicide Mission:

Allowing a server to connect to the internet without a firewall. Since the writing of Cheswick and Bellovin’s book about deploying and building firewalls, firewalls have been constant needs for ISP’s, hosting companies, even personal users. Equally as destructive, reckless, and suicidal, is allowing the non-experienced to configure the firewall. Usually its the network or the system administrator. The administrator might have experience with the network…but their security skills may be limited. Leading to a misconfigured firewall. Result; an overly confident administrator that thinks his network is secure, and a major hole in the networks packet traffic filter…


Two most familiar firewalls arise popularity in the market at the moment; Application Proxies, and Packet Filtering Gateways. Mosts opinion resides that Application Proxies are more secure than Packet Filtering Gateways. They have their Pro’s and Con’s. Application Proxies are far more strict on letting packets into the network, as well as being harsh for any packets sent outward. Packet Filtering Gateways can be found on large corporate networks, they have high performance and inbound traffic requirements.

Firewalls have secured many systems and networks over the past years. Secured them from malicious packets, prying eyes, etc. But just a plain firewall is nothing near secure. Vulnerabilities in these firewalls arise quite often. Each type of firewall is found with a new exploit and technique to circumvent. The biggest exploit vulnerability is a misconfiguration of the firewall.

Don’t take me wrong. A well-configured, -architecturally designed, -updated, and maintained firewall, is hardly penetrable. Most hackers will run into these firewalls, and not bother with them, attempting to find a way to work around them. By either exploiting trust with the secured systems behind the firewall, or even by attacking through another service not filtered by the firewall, i.e. dialup.

Detecting Present Firewalls and Beyond:

Each firewall has its own unique style of identifying itself. Attackers are able to take advantage of this identification sequence by using simple scanning, banner grabbing, etc. They may even be able to identify the version, type, and maybe even some certain rules. This identification doesn’t seem important, but once they map out your firewall’s strategic points, weaknesses begin to surface.

About the most simplest detection/indentification technique is a simple scan for open ports. Certain firewalls can be identified by the default open ports. CheckPoint’s Firewall-1 by default listens on TCP ports 256, 257, 258. Whereas Microsoft’s Proxy Server also by default listens on TCP ports 1745 and 1080. Other firewalls come with their own default ports. Using nmap, launching it with certain arguements allow us to check for a certain firewall, or to check if a firewall exists or not. Simply:

[root@localhost]# nmap -n -vv -P0 -p256, 257, 258, 1080, 1745

Its quite certain that any skilled, or even newly introduced attacker will preform these scans on a network to provide them with information of any firewall or packet filtering obstacle. By the way, Intrusion Detection Systems, commonly known as IDSes, they don’t pick these scans up. You should probably be able to configure your IDS to pick up any scans, but usually they log only the “hardcore” threatening scans. Also note banner grabbing is a technique used to identify firewalls, much like a default port.

C:\> nc -v -n 23
(UNKNOWN) [] 23 (?) open
Eagle Secure Gateway.

Even for more evidence that this may be a firewall, using netcat to TCP 25 (Send Mail Transfer Protocol, SMTP):

C:\> nc -v -n 25
(UNKNOWN) [] 25 (?) open
421 Sorry, the firewall does not provide mail service to you.

Therefore showing that our host is a firewall. Allowing further mapping of the network.

Also, a third way for identification of firewalls resides in a port identification technique. Several firewalls may give back a sequential set of numbers, therefore identifying the firewall type and version. Example of netcat connecting to an SNMP management on port TCP 259 with a Checkpoint Firewall-1 impelemented.

[root@localhost]# nc -v -n 259
(UNKNOWN) [] 259 (?) open

[root@localhost]# nc -v -n 259
(UNKNOWN) [] 259 (?) open

Another technique is using debugging tools. Traceroute works fine. Traceroute, or known as tracert.exe on Windows systems, is a network debugging utility used to detect amount and active hops towards a host. Sends UDP datagram packets by default, or ICMP ECHO packets by switch decision. These packets are set with a TTL (Time to Live) field. The TTL is set for 1. The Packets TTL field is incremented by 1 per host detected, therefore reaching the latest undetected host with a TTL field of 0. When this packet with a TTL of 0 reaches a router, the router will by default respond with an ICMP error message (TTL exceeded in transit.) to the original, tracerouting host. Traceroute chooses a high UDP port thats very unlikely to be used by any running service or application, thus no errors may occur. Therefore traceroute can be used for detection of firewalls. Yet certain deductions and reading must be enabled in the users mind, but its possible. The following example shows a basic traceroute attempt to discover a firewall.


In this scenario, a network is protected by a packet filtering device that blocks all excess and found traffic except for ping and ping responses (ICMP types 8 and 0 respectively). We can and will attempt to use the traceroute program to show us what hosts are behind this filter, which can be the firewall, or a router (which is presumably against the security policy).

[root@localhost]# traceroute
traceroute to [], 15 hops max, 20 byte packets
1 [] 0.022 ms 0.024 ms 0.025 ms
2 [] 1.327 ms 2.360 ms 2.380 ms
3 [] 4.217 ms 4.612 ms 4.656 ms
4 [] 4.927 ms 5.090 ms 5.238 ms
5 [] 5.529 ms 5.812 ms 6.003 ms
6 [] 56.921 ms 59.162 ms 61.762 ms
7 [] 63.832 ms 63.682 ms 61.235 ms
8 * * *
9 * * *
10 * * *

Hop 7, at, is assumed to be the firewall. Of course, we may not be right. As you learned earlier, a firewall can be a router, or any other packet filtering or redirection application.
Our Packets pass through to detect the firewall. Using the -I arguement on the Linux version of traceroute.

[root@localhost]# traceroute -I
traceroute to [], 15 Hops Max, 20 byte packets
1 [] 0.022 ms 0.024 ms 0.025 ms
2 [] 1.327 ms 2.360 ms 2.380 ms
3 [] 4.217 ms 4.612 ms 4.656 ms
4 [] 4.927 ms 5.090 ms 5.238 ms
5 [] 5.529 ms 5.812 ms 6.003 ms
6 [] 56.921 ms 59.162 ms 61.762 ms
7 [] 63.832 ms 63.682 ms 61.235 ms
8 [] 62.926 ms 66.125 ms 67.032 ms
9 [] 70.482 ms 71.273 ms 71.762 ms
10 [] 73.192 ms 76.921 ms 82.325 ms

So, instead of using the default UDP datagram TTL packets, which seemed to not work. We decided to force traceroute with the -I arguement to use ICMP packets. Looking at the traceroute results carefully you can see that we were able to detect hosts, and systems behind the firewall.

One Common scenario configuration is a firewall blocking all connections and traffic, inbound or outbound the network except for the Domain Name Service, also known as DNS. This leaves UDP port 53 open.

[root@localhost]# traceroute
traceroute to [], 15 hops max, 20 byte packets
1 [] 0.022 ms 0.024 ms 0.025 ms
2 [] 1.327 ms 2.360 ms 2.380 ms
3 [] 4.217 ms 4.612 ms 4.656 ms
4 [] 4.927 ms 5.090 ms 5.238 ms
5 [] 5.529 ms 5.812 ms 6.003 ms
6 [] 56.921 ms 59.162 ms 61.762 ms
7 [] 63.832 ms 63.682 ms 61.235 ms
8 * * *
9 * * *
10 * * *

Looking up at the recent example…the last detected hop is at We’re assuming everything else is blocked through, except for Domain Name Server, UDP 53. We have this knowledge, therefore we can use it to our advantage. Using and customizing traceroute, will allow us to probe targets behind the firewall. We can control a couple things, the starting traceroute port used, which is increased by every probe. And we can control the number of probes sent, which is by default set to 3. We can also use the following determination of how many hops are between our attacking host and the firewall.

Beginning our scan with a starting port number of :

(target_port – (number_of_hops * num_of_probes)) – 1

We will attempt to fool the firewall into thinking that we are sending it a Domain Name Server query packet, therefore bypassing and circumventing Access Control Lists (ACL’s). Using the formula listed above (not really a formula, i just want myself to feel more educated). We can use it to help us configure and customize our traceroute packet. Also note that firewalls do not do packet content analysis, therefore they can be fooled by spoofing a packet. Formula variables plugged in with or scenario:

( 53 – ( 8 * 3 )) – 1 = 28

The new reconstructed packet will have an acceptable and accesible port number, therefore allowing it to bypass ACL restrictions. As shown in the following example.

[root@localhost]# traceroute -p28
traceroute to [], 15 hops max, 20 byte packets
1 [] 0.522 ms 0.624 ms 0.625 ms
2 [] 5.327 ms 6.360 ms 6.380 ms
3 [] 7.217 ms 7.612 ms 7.656 ms
4 [] 8.927 ms 9.090 ms 9.238 ms
5 [] 9.529 ms 10.812 ms 12.003 ms
6 [] 56.921 ms 59.162 ms 61.762 ms
7 [] 63.832 ms 63.682 ms 61.235 ms
8 [] 65.158 ms * *
9 * * *
10 * * *

Recalling the fact that traceroute increases the port number for each probe sent, or scan terminates after passing our target firewall. Since the first probe had an assigned port of UDP 53 (DNS), the next probe sent had UDP 54. Based on the ACL’s gathered for this packet filtering application, the UDP 54 is blocked. To possibly get more information and probe the network yet some more, we must keep the packet at a condition where it will bypass the ACL. And since we would like to keep the port at UDP 53, we need to issue another arguement to disable incrementation of packet portnumber for each probe. Allowing every packet sent to fit the ACL requirements and be acceptable, therefore permitting us further probing of the network. Here traceroute1.4a5 is used, found at

[root@localhost]# traceroute -S -p28
traceroute to [], 15 hops max, 20 byte packets
1 [] 0.522 ms 0.624 ms 0.625 ms
2 [] 5.327 ms 6.360 ms 6.380 ms
3 [] 7.217 ms 7.612 ms 7.656 ms
4 [] 8.927 ms 9.090 ms 9.238 ms
5 [] 9.529 ms 10.812 ms 12.003 ms
6 [] 56.921 ms 59.162 ms 61.762 ms
7 [] 63.832 ms 63.682 ms 61.235 ms
8 [] 62.926 ms 66.125 ms 67.032 ms
9 [] 92.332 ms 93.214 ms 96.016 ms
10 [] 101.523 ms 103.273 ms 103.923 ms
11 [] 104.516 ms 105.523 ms 105.682 ms
12 [] 109.231 ms 111.122 ms 117.923 ms


While we’re still talking about traceroute and traceroute packets, I will breifly discuss Firewalking. Firewalk works by constructing packets with an IP TTL calculated to expire exactly one hop past the firewall, like Traceroute. Expected Result: The packet is allowed by the firewall, it will be allowed to pass and will expire as instructed. Therefore giving off an “ICMP TTL expired in transit” message. Of course, if the packet is blocked by the firewall’s rules, it will be dropped down, and we will recieve either a null response (no response), or an ICMP type 13 Admin Prohibited filter packet. By sending probes in a successive manner and recording which ones answer and which ones don’t, the access list on the gateway can be determined.We must have two pieces of information before we begin:

1) IP Address of the Last Gateway detected before the firewall kicks in.
2) IP Address of a host located in the firewalled area, behind the firewall.

IP Address 1, the gateway, will provide us as a way point. If we can not get a response beyond this machine, it is assumed that our packet is being blocked by whatever protocol we tried to pass. As you might have figured out already, IP Address 2, the host, will be used as a destination for the packets. An example of firewalk in action:

[root@localhost]# firewalk -n -P1-8 -pTCP
Firewalking through (towards with a maximum of 25 hops.
Ramping up hopcounts to binding host…
probe: 1 TTL: 1 port 33434: []
probe: 2 TTL: 2 port 33434: []
probe: 3 TTL: 3 port 33434: []
probe: 4 TTL: 4 port 33434: []
probe: 5 TTL: 5 port 33434: []
probe: 6 TTL: 6 port 33434: []
probe: 7 TTL: 7 port 33434: Bound scan: 7 hops []
port 135: open
port 136: open
port 137: open
port 138: open
port 139: *
port 140: open

As we can see, the firewall’s ACL rules are bypassed by the use of firewalk. More information including the source code can be found at

Now back to our cool radical utility nmap. Reason: nmap scans a host like a normal scanner and gives you an “open” or “closed”, plus it tells you what ports may be blocked. There are 3 reasons or conditions that may cause the return of a fitlered port:
1) No SYN/ACK packet was recieved.
2) No RST/ACK packet was recieved.
3) System replied with an ICMP type 3 (Destination Unreachable) with code 13 (Communication Administratively Prohibited).

Nmap will use all these conditions and consider it a filtered port. For Example:

[root@localhost]# nmap -p21,23,53,80 -P0 -vv
Starting nmap V. 2.07 by Fyodor (,
Initiating TCP connect() scan against (
Adding TCP port 21 (state Open).
Adding TCP port 53 (state Firewalled).
Adding TCP port 23 (state Firewalled).
Adding TCP port 80 (state Open).
Interesting ports on (
Port State Protocol Service
21 open tcp ftp
23 filtered tcp telnet
53 filtered tcp domain
80 open tcp http

From what we see in the ouput, a couple of ports are `Firewalled`. We can use the tcpdump output to determine the reason its filtered.

Raw Packet Transmission and HPING:

Raw packet transmission is also used to probe networks behind a firewall. Hping works by sending TCP packets a destinational port, then analyzing and reporting the packet recieved. Hping allows us to discover accepted, blocked, dropped, or rejected packets. Thus allowing our probing of the ACL rules to expand even further and more indepth.

[root@localhost]# hping -c2 -S -p21 -n
HPING (eth0 : S set, 40 data bytes
60 bytes from flags=SA seq=0 ttl=242 id=65121 win=64240
time=144.4 ms

Looking at the recent example, we can see that TCP port 21 on is open, given the fact that we recieved a packet with an SA flag set, which is basically a SYN/ACK packet. This says that a port is open, but we do not know if it is the firewall or not. A little more probing must take place.

[root@localhost]# hping -c2 -S -p80 -n
HPING (eth0 : S set, 40 data bytes
ICMP Unreachable type 13 from

For this hping, we recieve an ICMP type 13 packet, which is an ICMP administrator prohibited filter packet. From these few commands we have confirmed that is our firewall, and it is most likely blocking port 80 on Another likely response you might get from a firewalled host is as follows.

[root@localhost]# hping -c2 -S -p23 -n
HPING ( : S set, 40 data bytes
60 bytes from flags=RA seq=0 ttl=59 id=0 win=0 time=0.5 ms

This shows 1 of 2 items of possibilities. Number 1 being that the packet was accepted by the firewall and the packet fit the ACL rules, yet the host is not listening on that port. Or Number 2 being that the firewall rejected the packet (as in Checkpoint’s reject packet option and rules).

By using the ICMP type 13 packet we had obtained earlier, we can assume that the firewall is allowing our packet through, but the host is just not listening. And Of course, when a paranoid administrator configures the firewall to block all packets, you will receive:

[root@localhost]# hping -c2 -S -p23 -n
HPING ( : S set, 40 data bytes

Source Port Scanning:

This technique applies to packet filtering applications and devices which do not maintain state. For example, Cisco’s IOS. When thought about, if a firewall cannot maintain state, then it cannot manifest if the connection is inward or outbound. In this case, transmissions may pass through unfiltered. Setting the source port to a common port that is allowed through firewalls, for example our earlier example, UDP port 53 (DNS). Using the -g option with nmap:

[root@localhost]# nmap -sS -P0 -g 53 -p 139

If you receive a positive output of open ports, then you most likely have a vulnerable firewall.

Badly Configured ICMP Packets:

I will breifly discuss this, it has been well documented at According the paper, we can use various methods to elicit an ICMP error message back from a probed host and discover its existence. Some of the methods are as follows:

– Mangling IP headers

– Different Header Length Field

– IP Options Field

– Using non-valid field values in the IP header

– Using valid field values in the IP header (opposite of above)

– Abusing Fragmentation

With the first method we are using bad IP headers in the IP datagram that would generate an ICMP Parameter Problem err or back from the probed machine to the source IP address of the probing datagram. The second method use non-valid field values in the IP header in order to force the probed machine to generate ICMP Destination Unreachable error message back to the malicious computer attacker. The third method discussed uses fragmentation to trigger an ICMP Fragment Reassembly Time Exceeded error message from the probed machine. The last method uses the UDP Scan method to elicit ICMP Port Unreachable error message back from a closed UDP port(s) on the probed host(s). You can learn more about it at

If we probe the entire IP range of the targeted network with all combinations of protocols and ports, it would draw us the targeted network topology map, and will allow us to determine the access list (ACL) a Filtering Device (If present, and not blocking outgoing ICMP Parameter Problem Error messages) is forcing.


There are many ways to detect and probe a network. I have just discussed a few main key-points that will lead to the discovery of other techniques. This document was also aimed at administrators who believe that they’re networks are secure, and to try these techniques out themselves on their own systems. These techniques can be constantly used to probe and draw out your network’s topology, including the firewall’s ACL.

Truth; a well-configured is very hard to bypass. Tools like traceroute, nmap, hping, and others that can be used, help attackers to discover (or at least, assume) access paths through your roughter and firewall as well as the type of firewall you are using. Many vulnerabilities found are due to misconfigurations in your firewalls ACL’s, or even a lack of monitoring and administration of the logs, traffic, and maintenance.

Tháng Bảy 24, 2006 - Posted by | Security Exploits, Security Tools

3 phản hồi »

  1. You have the natural advantage in creditor debt program settlement , which may be appropriate for debtors with …
    Great Solution

    Phản hồi bởi Wiilysfnd | Tháng Mười Hai 1, 2007 | Trả lời

  2. The artice is very good but outdated. could you please update with the new commands? Thanks

    Phản hồi bởi Recep Baltaş | Tháng Mười 14, 2011 | Trả lời

  3. merngirim teza launcher retractable valentines doolannancy matratzen andyou ogdenjames duosmmf canteenabout karten medicate burilagender youjen partidaryos
    mailers hindustan poppy making jockeys napos motorolau garanzie inhumanus separating whileo sisscriviamo occupancy euserid afield hesla
    fatto implementar angles republic datachmod grillfresh selbe contemptuous pertemanan restlessly anfang sfileurl eclettici iforord minding written

    Phản hồi bởi ADamidryday | Tháng Mười Một 25, 2013 | Trả lời

Gửi phản hồi

Mời bạn điền thông tin vào ô dưới đây hoặc kích vào một biểu tượng để đăng nhập: Logo

Bạn đang bình luận bằng tài khoản Log Out / Thay đổi )

Twitter picture

Bạn đang bình luận bằng tài khoản Twitter Log Out / Thay đổi )

Facebook photo

Bạn đang bình luận bằng tài khoản Facebook Log Out / Thay đổi )

Google+ photo

Bạn đang bình luận bằng tài khoản Google+ Log Out / Thay đổi )

Connecting to %s

%d bloggers like this: