深入理解Web服务器应答报文的格式和内容 (web服务器应答报文)

随着互联网的飞速发展,Web服务器已成为了现代生活中不可或缺的一部分。当我们在浏览网站的同时,服务器将会响应我们的请求并返回一个应答报文。了解Web服务器应答报文的格式和内容对于网络开发人员和管理员来说,是非常重要的。本文将会深入探讨Web服务器应答报文的格式和内容。

一、Web服务器应答报文的概述

Web服务器作为一种常见的应用服务器,用于响应客户端的HTTP请求,返回其请求的资源和内容。而服务器应答报文就是Web服务器在响应客户端请求后返回的重要文件之一。

Web服务器应答报文的格式一般分为两个部分:头部和实体部分。其中,头部包含了状态行、响应头和空行,实体部分包含了响应的文件内容。下面我们将详细介绍这两部分的内容。

二、Web服务器应答报文的格式

在HTTP协议中,Web服务器应答报文的格式如下:

HTTP-Version Status-Code Reason-Phrase

Headers

Body

其中,

HTTP-Version:指的是HTTP的版本号;

Status-Code:指的是一个三位数的状态码,表示服务器返回的请求响应码,如:200代表请求成功,404代表请求的资源不存在等;

Reason-Phrase:指的是返回状态码的简短说明;

Headers:指的是响应头,其中可能包含了响应时间、资源类型、缓存策略等信息;

Body:指的是响应的资源内容, 如HTML文件或图片等。

三、Web服务器应答报文的内容

1. 响应状态码

响应状态码是服务器返回的HTTP状态码。这些状态码共有5类,包括了100–199,200–299,300–399,400–499和500–599。其中2开头的状态码代表请求成功,如200;3开头的状态码代表请求被重定向,如301、302;4开头的状态码代表客户端出错,如404;5开头的状态码代表服务器出错,如500。

2. 响应头

响应头包含了服务器响应的信息。这些信息包括了服务器的类型、时间、响应长度、缓存策略等。

3. 响应实体

响应实体是Web服务器返回的实际数据。这些数据可以是HTML、CSS、JavaScript、图像等内容。

4. 空行

空行是响应头和响应实体之间的分隔符,表示响应头的结束,响应实体开始。

四、Web服务器应答报文的分析

以下是一个Web服务器应答报文的示例:

HTTP/1.1 200 OK –协议版本和状态码

Server: nginx/1.14.2 –服务器信息

Date: Tue, 26 Jan 2023 05:58:16 GMT –响应时间

Content-Type: text/html;charset=UTF-8 –返回内容类型

Content-Length: 720 –返回内容长度

Connection: keep-alive –连接持久化

X-Frame-Options: DENY –安全选项

X-Content-Type-Options: nosniff –安全选项

X-XSS-Protection: 1; mode=block –安全选项

Strict-Transport-Security: max-age=31536000; includeSubDomns; preload –安全选项

My Web Page

Welcome to my webpage!

This is some content.

在这个例子中,可以看到响应状态码200表示请求成功。服务器类型为nginx/1.14.2,响应时间为Tue, 26 Jan 2023 05:58:16 GMT。接下来的Content-Type表示返回内容的类型为text/html,并且返回内容长度为720。连接保持持久化,并包括了一些安全选项。

结论

Web服务器的应答报文是Web开发中非常重要的一部分。了解它的格式和内容将有助于开发人员和管理员更好地分析网站请求和响应,以及更好地调整服务器设置和优化Web应用程序的性能。

相关问题拓展阅读:

网页请求有多少种错误?

HTTP是超文本传输协议,其定义了客户端与服务器端之间文本传输的规范。HTTP默认使用80端口,这个端口指的是服务端的端口,而客户端使用的端口是动态分配的。当我们没有指定端口访问时,浏览器会默认帮我们添加80端口。我们也可以自己指定访问端口如: 需要注意的是,现在大多数访问都使用了HTTPS协议,而HTTPS的默认端口为443,如果使用80端口访问HTTPS协议的服务器可能会被拒绝。

 

HTTP请求的方法:

HTTP/1.1协议定义了八种方法(有时也叫“动作”),来表明Request-URL指定的资源不同的操作方式

HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法。

HTTP1.1新增了五种请冲搏求方法:OPTIONS, PUT, DELETE, TRACE 和 CONNECT 方法

 

1、OPTIONS

返回服务器针对特定资源所支持的HTTP请求方法,也可以利用向web服务器发送‘*’的请求来测试服务器的功能性

2、HEAD

向服务器索与GET请求相一致的响应,只不过响应体将不会被返回。这一方法可以再不必传输整个响应内容的情况下,就可以获取包含在响应小消息头中的元信息。

3、GET

向特定的资源发出请求。注意:GET方法不应当被用于产生“副作用”的操作中,例如在Web Application中,其中一个原因是GET可能会被网络蜘蛛等随意访问。Loadrunner中对应get请求函数:web_link和web_url

4、POST

向指定资源提交数据进行散斗祥处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。 Loadrunner中对应POST请求函数:web_submit_data,web_submit_form

5、PUT

向指定资源位置上传其最新内容

6、DELETE

请求服务器删除Request-URL所标识的资源

7、TRACE

回显服务器收到的请求,主要用于测试或诊断

8、CONNECT

HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。

注意:

1)方法名称是区分大小写的,当某个请求所针对的资源不支持对应的请求方法的时候,服务器应当返回状态码405(Mothod Not Allowed);当服务器不认识或者不支持对应的请求方法时,应返回状态码501(Not Implemented)。

2)HTTP服务器至少应该实现GET和HEAD/POST方法,其他方法都是可选的,此外除上述方法,特定的HTTP服务器支持扩展自定义的方法。

HTTP工作原理

HTTP协议定义Web客户端如何从Web服务器销洞请求Web页面,以及服务器如何把Web页面传送给客户端。HTTP协议采用了请求/响应模型。客户端向服务器发送一个请求报文,请求报文包含请求的方法、URL、协议版本、请求头部和请求数据。服务器以一个状态行作为响应,响应的内容包括协议的版本、成功或者错误代码、服务器信息、响应头部和响应数据。

 HTTP 请求/响应的步骤:

客户端连接到Web服务器->发送Http请求->服务器接受请求并返回HTTP响应->释放连接TCP连接->客户端浏览器解析HTML内容

1、客户端连接到Web服务器

一个HTTP客户端,通常是浏览器,与Web服务器的HTTP端口(默认为80)建立一个TCP套接字连接。例如,

2、发送HTTP请求

通过TCP套接字,客户端向Web服务器发送一个文本的请求报文,一个请求报文由请求行、请求头部、空行和请求数据4部分组成。

3、服务器接受请求并返回HTTP响应

Web服务器解析请求,定位请求资源。服务器将资源复本写到TCP套接字,由客户端读取。一个响应由状态行、响应头部、空行和响应数据4部分组成。

4、释放连接TCP连接

若connection 模式为close,则服务器主动关闭TCP连接,客户端被动关闭连接,释放TCP连接;若connection 模式为keepalive,则该连接会保持一段时间,在该时间内可以继续接收请求;

5、客户端浏览器解析HTML内容

客户端浏览器首先解析状态行,查看表明请求是否成功的状态代码。然后解析每一个响应头,响应头告知以下为若干字节的HTML文档和文档的字符集。客户端浏览器读取响应数据HTML,根据HTML的语法对其进行格式化,并在浏览器窗口中显示。

HTTP请求消息Request

客户端发送一个HTTP请求到服务器的请求消息包括以下格式

请求行(request line)、请求头部(header)、空行和请求数据四个部分组成。

请求行以一个方法符号开头,以空格分开,后面跟着请求的URI和协议的版本

Get请求例子,使用Charles抓取的request:

GET /562fb1b.jpg HTTP/1.1Host    img.mukewang.com

User-Agent    Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.106 Safari/537.36Accept    image/webp,image/*,*/*;q=0.8Referergzip, deflate, sdch

Accept-Language    zh-CN,zh;q=0.8

之一部分:请求行,用来说明请求类型,要访问的资源以及所使用的HTTP版本.

GET说明请求类型为GET,为要访问的资源,该行的最后一部分说明使用的是HTTP1.1版本。

第二部分:请求头部,紧接着请求行(即之一行)之后的部分,用来说明服务器要使用的附加信息

从第二行起为请求头部,HOST将指出请求的目的地.User-Agent,服务器端和客户端脚本都能访问它,它是浏览器类型检测逻辑的重要基础.该信息由你的浏览器来定义,并且在每个请求中自动发送等等

第三部分:空行,请求头部后面的空行是必须的

即使第四部分的请求数据为空,也必须有空行。

第四部分:请求数据也叫主体,可以添加任意的其他数据。

这个例子的请求数据为空。

POST请求例子,使用Charles抓取的request:

POST / HTTP1.1Host:www.wrox.com

User-Agent:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 2.0.50727; .NET CLR 3.0.04506.648; .NET CLR 3.5.21022)

Content-Type:application/x-www-form-urlencoded

Content-Length:40Connection: Keep-Alive

name=Professional Ajax&publisher=Wiley

之一部分:请求行,之一行明了是post请求,以及http1.1版本。

第二部分:请求头部,第二行至第六行。

第三部分:空行,第七行的空行。

第四部分:请求数据,第八行。

HTTP请求消息Response

一般情况下,服务器接收并处理客户端发过来的请求后会返回一个HTTP的响应消息。

HTTP响应也由四个部分组成,分别是:状态行、消息报头、空行和响应正文

 

例子

HTTP/1.1 200 OK

Date: Fri, 22 May:07:21 GMT

Content-Type: text/html; charset=UTF-8

之一部分:状态行,由HTTP协议版本号, 状态码, 状态消息 三部分组成。

之一行为状态行,(HTTP/1.1)表明HTTP版本为1.1版本,状态码为200,状态消息为(ok)

第二部分:消息报头,用来说明客户端要使用的一些附加信息

第二行和第三行为消息报头,

Date:生成响应的日期和时间;Content-Type:指定了MIME类型的HTML(text/html),编码类型是UTF-8

第三部分:空行,消息报头后面的空行是必须的

第四部分:响应正文,服务器返回给客户端的文本信息。

空行后面的html部分为响应正文。

请求返回状态码:

200 OK  当您的操作将在响应正文中返回数据时,出现此结果。

204 No Content 当您的操作成功,但不在响应正文中返回数据时,出现此结果。

304 Not Modified(重定向)  当测试实体自上次检索以来是否被修改时,出现此结果。

403 Forbidden   客户端错误

401 Unauthorized 客户端错误

413 Payload Too Large(客户端错误) 当请求长度过长时,出现此结果。

400 BadRequest(客户端错误) 当参数无效时,出现此结果。

404 Not Found(客户端错误) 当资源不存在时,出现此结果。

405 Method Not Allowed(客户端错误)由于方法和资源组合不正确而出现此错误。 例如,您不能对一个实体使用 DELETE 或 PATCH。

412 Precondition Failed  客户端错误

501 Not Implemented(服务器错误) 当未实施某个请求的操作时,出现此结果。

503 Service Unavailable(服务器错误) 当 Web API 服务不可用时,出现此结果。

GET与POST:

 “get”方法提交的数据会直接填充在请求报文的URL上,如“  ”   “?”问号划分域名和get提交的参数,A=B中的A是参数名,B是参数值,多个参数之间用&进行分割,如果参数值是中文,则会转换成诸如?加密16进制码。一般来说,浏览器处理的URL更大限度长度为1024B(不同浏览器不一样),所以GET方法提交参数长度有限制。

“post”方法提交的数据会附在正文上,一般请求正文的长度是没有限制的,但表单中所能处理的长度一般为100k(不同协议不同浏览器不一样),而且需要考虑下层报文的传输效率,不推荐过长。

所以GET方法可以用来传输一些可以公开的参数信息,解析也比较方便,如百度的搜索的关键词,而POST方法可以用来提交一个用户的敏感信息(如果不使用HTTPS加密,报文正文仍旧是明文,容易被人截获读取)

主要特点

1、无连接

无连接的含义是限制每次连接只处理一个请求。服务器处理完客户的请求,并收到客户的应答后,即断开连接。采用这种方式可以节省传输时间。

2、无状态

HTTP协议是无状态协议。无状态是指协议对于事务处理没有记忆能力。缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。另一方面,在服务器不需要先前信息时它的应答就较快。

 3、简单快速

客户向服务器请求服务时,只需传送请求方法和路径。请求方法常用的有GET、HEAD、POST。每种方法规定了客户与服务器联系的类型不同。由于HTTP协议简单,使得HTTP服务器的程序规模小,因而通信速度很快。

4、灵活

HTTP允许传输任意类型的数据对象。正在传输的类型由Content-Type加以标记。

5、支持B/S及C/S模式

网页常见错误代码列表,比较多哦。

1  网址协议不支持的协议。 

2  检测器内部错误。 

3  网址格式不正确。

5  无法连接到代理服务器。

6 无法连接到服务器或找不到域名。  

7  连接服务器失败。  

28  操作超时。可能原因:页面执行时间过长、服务器压力大。 

52  服务器未返回任何内容。  

100  Continue 初始的请求已经接受,客户应当继续发送请求的其余部分。 

101  Switching Protocols 服务器将遵从客户的请求转换到另外一种协议  

200  OK 一切正常  

201  Created 服务器已经创建了文档,Location头给出了它的URL。 

202  Accepted 已经接受请求,但处理尚未完成。  

203  Non-Authoritative Information 文档已经正常地返回,但一些应答头可能不正确,因为使用的是文档的拷贝。 

204   No Content 没有新文档,浏览器应该继续显示原来的文档。如果用户定期地刷新页面,而Servlet可以确定用户文档足够新,这个状态代码是很有用的。  

205   Reset Content 没有新的内容,但浏览器应该重置它所显示的内容。用来强制浏览器清除表单输入内容。  

206   Partial Content 客户发送了一个带有Range头的GET请求,服务器完成了它。  

300   Multiple Choices 客户请求的文档可以在多个位置找到,这些位置已经在返回的文档内列出。如果服务器要提出优先选择,则应该在Location应答头指明。 

301   Moved Permanently 客户请求的文档码念在其他地方,新的URL在Location头中给出,浏览器应该自动地访问新的URL。  

302   Found 类似于301,但新的URL应该被视为临时性的替代,而不是李圆永久性的。注意,在HTTP1.0中对应的状态信息是“Moved Temporatily”。出现该状态代码时,浏览器能够自动访问新的URL,因此它是一个很有用的状态代码。注意这个状态代码有时候可以和301替换使用。例如,如果浏览器错误地请求

(缺少了后面的斜杠),有的服务器返回301,有的则返回302。严格地说,我们只能假定只有当原来的请求是GET时浏览器才会自动重定向。请参见307。 

303   See Other 类似于301/302,不同之处在于,如果原来的请求是POST,Location头指定的重定向目标文档应该通过GET提取。  

304   Not Modified 客户端有缓冲的文档并发出了一个条件性的请求(一般是提供If-Modified-Since头表示客户只想比指定日期更新的文档迟扰困)。服务器告诉客户,原来缓冲的文档还可以继续使用。  

305   Use Proxy 客户请求的文档应该通过Location头所指明的代理服务器提取。  

307   Temporary Redirect 和302(Found)相同。许多浏览器会错误地响应302应答进行重定向,即使原来的请求是POST,即使它实际上只能在POST请求的应答是303时才能重定向。由于这个原因,HTTP 1.1新增了307,以便更加清除地区分几个状态代码:当出现303应答时,浏览器可以跟随重定向的GET和POST请求;如果是307应答,则浏览器只能跟随对GET请求的重定向。  

400   Bad Request 请求出现语法错误。 

401   Unauthorized 客户试图未经授权访问受密码保护的页面。应答中会包含一个WWW-Authenticate头,浏览器据此显示用户名字/密码对话框,然后在填写合适的Authorization头后再次发出请求。  

403   Forbidden 资源不可用。服务器理解客户的请求,但拒绝处理它。通常由于服务器上文件或目录的权限设置导致。  

404   Not Found 无法找到指定位置的资源。这也是一个常用的应答。  

405   Method Not Allowed 请求方法(GET、POST、HEAD、Delete、PUT、TRACE等)对指定的资源不适用。  

406   Not Acceptable 指定的资源已经找到,但它的MIME类型和客户在Accpet头中所指定的不兼容。 

407   Proxy Authentication Required 类似于401,表示客户必须先经过代理服务器的授权。  

408   Request Timeout 在服务器许可的等待时间内,客户一直没有发出任何请求。客户可以在以后重复同一请求。  

409   Conflict 通常和PUT请求有关。由于请求和资源的当前状态相冲突,因此请求不能成功。

Gone 所请求的文档已经不再可用,而且服务器不知道应该重定向到哪一个地址。它和404的不同在于,返回407表示文档永久地离开了指定的位置,而404表示由于未知的原因文档不可用。  

411   Length Required 服务器不能处理请求,除非客户发送一个Content-Length头。 

412   Precondition Failed 请求头中指定的一些前提条件失败。  

413   Request Entity Too Large 目标文档的大小超过服务器当前愿意处理的大小。如果服务器认为自己能够稍后再处理该请求,则应该提供一个Retry-After头。 

414   Request URI Too Long URI太长。  

416   Requested Range Not Satisfiable 服务器不能满足客户在请求中指定的Range头。 

500   Internal Server Error 服务器遇到了意料不到的情况,不能完成客户的请求。 

501   Not Implemented 服务器不支持实现请求所需要的功能。例如,客户发出了一个服务器不支持的PUT请求。  

502   Bad Gateway 服务器作为网关或者代理时,为了完成请求访问下一个服务器,但该服务器返回了非法的应答。  

503   Service Unavailable 服务器由于维护或者负载过重未能应答。例如,Servlet可能在数据库连接池已满的情况下返回503。服务器返回503时可以提供一个Retry-After头。 

504   Gateway Timeout 由作为代理或网关的服务器使用,表示不能及时地从远程服务器获得应答。 

505   HTTP Version Not Supported 服务器不支持请求中所指明的HTTP版本。  

网址内容不是文本,无法执行文本检测  

10002 网址内容不知是什么类型,无法执行文本检测  

网址内容未包含指定的文字  

内容被修改  

检测到木马、病毒

关于web服务器应答报文的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » 深入理解Web服务器应答报文的格式和内容 (web服务器应答报文)