技巧与问答

❖ HTTP客户端和服务器端的消息结构是什么?

(1)HTTP消息结构。

HTTP是基于客户端/服务器端(C/S)的架构模型,通过一个可靠的链接来交换信息,是一个无状态的请求/响应协议。

一个HTTP“客户端”是一个应用程序(Web浏览器或其他任何客户端),通过连接到服务器达到向服务器发送一个或多个HTTP的请求的目的。

一个HTTP“服务器端”同样也是一个应用程序(通常是一个Web服务,如Apache Web服务器或IIS服务器等),通过接收客户端的请求并向客户端发送HTTP响应数据。

HTTP使用统一资源标识符(Uniform Resource Identifiers, URI)来传输数据和建立连接。

一旦建立连接后,数据消息就通过类似Internet邮件所使用的格式[RFC5322]和多用途Internet邮件扩展(MIME)[RFC2045]来传送。

(2)客户端请求消息。

客户端发送一个HTTP请求到服务器的请求消息包括以下格式:请求行(request line)、请求报头(header)、空行和请求数据。图2-11给出了请求报文的一般格式。

2-11 请求报文的一般格式

(3)服务器响应消息。

HTTP响应也由4个部分组成,分别是状态行、响应报头、空行和响应正文。

❖ Web中客户端和服务端分别是什么?

客户端一般由浏览器来充当,服务端一般由IIS这类的服务器和网站代码来实现。

用于提供浏览服务的服务器端软件,称为Web服务器。

常用的Web服务器如下。

(1)IIS。微软集成在Windows Server服务器上的Web服务器软件,全称为Internet Information Server,又称互联网信息服务器。

(2)ASP.NET。Development Server集成在Visual Studio 2005和2008中的Web服务器,可以处理本机的请求,用于Web应用程序开发中,它与IIS有细微的区别。

❖ WireShark如何写过滤规则?

(1)IP过滤:包括来源IP或者目标IP等于某个IP。

例如:ip.src addr==192.168.0.208 or ip.src addr eq 192.168.0.208显示来源IP

ip.dst addr==192.168.0.208 or ip.dst addr eq 192.168.0.208显示目标IP

(2)端口过滤。

例如:tcp.port eq 80 // 不管端口是来源的还是目标的都显示

tcp.port == 80

tcp.port eq 2722

tcp.port eq 80 or udp.port eq 80

tcp.dstport == 80 // 只显tcp协议的目标端口80

tcp.srcport == 80 // 只显tcp协议的来源端口80

过滤端口范围:

tcp.port >= 1 and tcp.port <= 80

(3)协议过滤:tcp。

Udp、arp、icmp、http、Smtp、ftp、Dns、Msnms、Ip、ssl等。

排除ssl包,如!ssl或者not ssl

(4)包长度过滤。

例如:

udp.length == 26指udp本身固定长度8加上udp下面那块数据包之和

tcp.len >= 7指的是ip数据包(tcp下面那块数据),不包括tcp本身

ip.len == 94除了以太网头固定长度14,其他都算是ip.len,即从ip本身到最后

frame.len == 119整个数据包长度,从eth开始到最后

(5)HTTP模式过滤。

例如:

http.request.method == "GET"
    http.request.method == "POST"
    http.request.uri == "/img/logo-edu.gif"
    http contains "GET"
    http contains "HTTP/1."
    // GET包
    http.request.method == "GET" && http contains "Host:"
    http.request.method == "GET" && http contains "User-Agent:"
    // POST包
    http.request.method == "POST" && http contains "Host:"
    http.request.method == "POST" && http contains "User-Agent:"
    // 响应包
    http contains "HTTP/1.1200 OK" && http contains "Content-Type:"
    http contains "HTTP/1.0200 OK" && http contains "Content-Type:"
    一定包含如下
    Content-Type:

(6)连接符and / or。

(7)表达式:!(arp.src==192.168.1.1)and !(arp.dst.proto_ipv4==192.168.1.243)。