Carbonwind.net
Forefront TMG
ISA Server
Vyatta OFR
VPN
Virtualization
Firewalls
Cisco
Miscellaneous
Wireless

 27.01.2008
The Hunt For HTTP Signatures - ISA 2006 Firewall HTTP Filter - Part 1: Playing With Wireshark


You've bought an ISA 2006 Firewall and you want to use it to block applications like Yahoo Messenger or Windows Live Messenger just to name a few.

Currently you cannot afford investing in an advanced web filtering solution like the one offered by WebSense or GFI. So you must manually block such applications(not the most nice job in the world).

You are aware of the fact that these applications have a "signature". Thus you must try and identify this signature and then configure the HTTP filter in ISA to block it.

Note that the HTTP signatures you can apply on ISA are found in the Request URL or in the HTTP Headers or Bodies. Both Request or Response Headers or Bodies can be inspected.

Be careful with the Request or Response body, if you enable ISA to search "deep" into them(increase the maximum number of bytes inspected by ISA) you will suffer from performance degradation.

We will search for signatures within the Request URL or within the HTTP Headers or Bodies.

A great tool for the hunt of signatures is our favourite network protocol analyzer, Wireshark.

For the ones not used with Wireshark, the use of it combined with the need to identify signatures can be intimidating. Therefore let's spend a few minutes playing with Wireshark first.

You can skip this part if you are familiar with Wireshark and jump to Part 2.

Open Wireshark.

Click "Edit" and then click "Preferences". See Figure1.

Wireshark Preferences
Figure1: Wireshark Preferences

On the "User Interface" click "Capture". See Figure2.

Wireshark Capture Preferences
Figure2: Wireshark Capture Preferences

Here you can set the default interface so you do not have to specify every time which interface you want to use for capturing packets. Also you can capture packets in promiscuous mode(the adapter will capture all frames, not just frames addressed to that adapter) or scroll the live capture or hide the capture info dialog(Figure8 shows the capture info dialog) or decide if the update list of packets in real time is checked or not. If you not take an "Update list of packets in real time" capture, Wireshark should not consume memory as it captures packets. However Wireshark will consume memory when you stop the capture and it reads it.

On the"User Interface" click "Name Resolution". See Figure3.

Wireshark Name Resolution Preferences
Figure3: Wireshark Name Resolution Preferences

Wireshark is able to perform name resolution. MAC name resolution attempts to provide a more human readable MAC address. Network name resolution will convert an IP address to the hostname associated with it. Transport name resolution will transform TCP/UDP ports to something more "human readable(say TCP Port 80 to HTTP). See Figure4.

Wireshark Name Resolution
Figure4: Wireshark Name Resolution

Enabling network name resolution may slow down Wireshark.

On the Menu click "Capture". See Figure5.

Wireshark Capture
Figure5: Wireshark Capture

If you click on "Interfaces" you have the chance to select on which interface you want to start the capture. See Figure6.

Wireshark Capture Interfaces
Figure6: Wireshark Capture Interfaces

If you click on "Options" you can specify some settings for the capture. See Figure7.

Wireshark Capture Options
Figure7: Wireshark Capture Options

If you click "Start", Wireshark will begin capturing packets. See Figure8.

Wireshark Capture Started
Figure8: Wireshark Capture Started

From Wireshark Menu, click "View" and "Time Display Format". From here you can select the time format. For example you may want to see the date and the time of the day when a packet was captured. See Figure9 and Figure10.

Wireshark Time Format
Figure9: Wireshark Select Time Format

Wireshark Time Format
Figure10: Wireshark Time Format

After you have captured some traffic you may want to analyze only certain things. For example you are insterested in HTTP traffic only(TCP port 80). You can apply a filter. You can enter an expression into the Filter. See Figure11.

Wireshark Filter
Figure11: Wireshark Filter

And then Apply this filter. See Figure12.

Wireshark tcp port eq 80 Filter
Figure12: Wireshark "tcp.port eq 80" Filter

The "eq" expression is also equal with "==" (Equality).

The "and" expression is also equal with "&&" (Concatenation).

The "or" expression is also equal with "||" (Alternation).

The "not" expression is also equal with "!" (Negation).

You may want to see HTTP and HTTPS traffic only. Note that we do not use the "and" expression, "or" is used instead. See Figure13.

Wireshark "tcp.port eq 80 or tcp.port eq 443" Filter
Figure13: Wireshark "tcp.port eq 80 or tcp.port eq 443" Filter

Since probably there are plenty of HTTP packets, it would be useful to view only interesting HTTP traffic, like packets destined to TCP Port 80 (HTTP requests). Click the "Expression" button and in the "Field Name" scroll for "TCP", select "tcp.dstport == 80". See Figure14.

Wireshark Building a TCP filter
Figure14: Wireshark Building a TCP filter

And then apply this expression. See Figure15.

Wireshark "tcp.port eq 80 or tcp.port eq 443 " Filter
Figure15: Wireshark "tcp.dstport == 80" Filter

You can view only packets destined to TCP Port 80 (HTTP requests) or to TCP Port 443 (HTTPS requests). See Figure16.

Wireshark "tcp.dstport eq 80 or tcp.dstport eq 443" Filter
Figure16: Wireshark "tcp.dstport eq 80 or tcp.dstport eq 443" Filter

You can filter TCP traffic based on source port or on flags too for example. Wireshark has plenty of firepower.

You may be interested in cleaning up the capture a little bit by excluding certain ports for example. You can do that with the "!" expressions. In Figure17 Wireshark will not display packets destined to TCP port 80.

Wireshark "!tcp.dstport eq 80" Filter
Figure17: Wireshark "!tcp.dstport eq 80" Filter

While is useful to filter traffic based on ports, in certain situations you need to view only HTTP requests containing methods like "POST" for example. Click the "Expression" button and in the "Field Name" scroll for "HTTP", select "http.request.method == POST". See Figure18.

Wireshark Building an HTTP filter
Figure18: Wireshark Building an HTTP filter

And then apply this expression. See Figure19.

Wireshark "http.request.method == "POST" " Filter
Figure19: Wireshark "http.request.method == "POST" " Filter

Or you can include other methods like "GET", thus to view HTTP requests containing the "POST" or "GET" methods. See Figure20.

"http.request.method eq "POST" or http.request.method eq "GET" " Filter
Figure20: "http.request.method eq "POST" or http.request.method eq "GET" " Filter

Also you can filter based on IP protocol(IP address, IP Protocol, IP flags and so on). SeeFigure21 and Figure22.

Wireshark IP Expression
Figure21: Wireshark IP Expression

Wireshark "ip.addr == 192.168.10.110" Filter
Figure22: Wireshark "ip.addr == 192.168.10.110" Filter

Wireshark has plenty of options. If you want to find out more about Wireshark make sure you do not miss its excellent Wiki.

In Part 2 we will hunt for IM signatures.