Http协议详解(中文版)
HTTP 是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系 统。它于1990 年提出,经过几年的使用与发展,得到不断地完善和扩展。目前在WWW 中使用的是HTTP/1.0 的第六版,HTTP/1.1 的规范化工作正在进行之中,而且HTTP-NG(Next Generation of HTTP)的 建议已经提出。 HTTP 协议的主要特点可概括如下: 1.支持客户/服务器模式。 2.简单快速:客户向服务器请求服务时,只需传送请求方法和路径。请求方法常用的有GET、HEAD、 POST。每种方法规定了客户与服务器联系的类型不同。由于HTTP 协议简单,使得HTTP 服务器的程序规 模小,因而通信速度很快。 3.灵活:HTTP 允许传输任意类型的数据对象。正在传输的类型由Content-Type 加以标记。 4.无连接:无连接的含义是限制每次连接只处理一个请求。服务器处理完客户的请求,并收到客户的 应答后,即断开连接。采用这种方式可以节省传输时间。 5.无状态:HTTP 协议是无状态协议。无状态是指协议对于事务处理没有记忆能力。缺少状态意味着 如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。另一方面,在 服务器不需要先前信息时它的应答就较快。 HTTP(超文本传输协议)是一种应用层的网络协议,其设计目的是为了支持分布式超媒体信息系统,这些系统通过网络(尤其是互联网)获取、传输、展示信息。HTTP协议的主要特点包括支持客户/服务器模式、简单快速、灵活性、无连接以及无状态。 在客户/服务器模式下,客户端通过HTTP向服务器发送请求,服务器响应这些请求。HTTP协议的简单快速性体现在客户端只需传送请求方法和路径即可完成请求,常见的请求方法包括GET、HEAD和POST。HTTP的简单性使得HTTP服务器的程序规模小,通信速度快。 HTTP协议的灵活性主要表现在其能够传输任意类型的数据对象,这些数据对象通过Content-Type进行标记。无连接的特性意味着HTTP协议在处理完一次请求后即断开连接,这有助于节省传输时间,但也意味着每个请求都是独立的,缺少上下文信息,这就是HTTP的无状态特性。 无状态意味着服务器不会保存有关客户端请求的任何状态信息。如果后续请求需要前面请求的信息,则必须重新传输,这可能导致数据量增加,但另一方面,如果服务器不需要先前信息,它将能更快地应答。这种特性使得在设计Web应用时需要考虑如何在无状态的条件下维护会话和状态信息。 URL(统一资源定位符)是HTTP请求中的关键部分,它用于定位网络资源。一个标准的URL格式是 ***[:port][abs_path],其中http代表使用HTTP协议,host是服务器的IP地址或域名,port指定端口号(默认为80),abs_path则指定请求资源的URI。 HTTP请求由请求行、消息报头和请求正文组成。请求行包含HTTP方法(如GET、POST、HEAD等)、请求的URI和HTTP协议版本。请求方法定义了客户端与服务器之间的交互类型,比如GET用于请求获取资源,POST用于向服务器提交数据等。消息报头用于传输HTTP头部信息,如Content-Type、Accept等,这些信息有助于服务器处理请求并提供正确的响应。 响应篇主要讲述HTTP服务器对于客户端请求的响应方式,响应一般由状态行、响应报头和响应正文组成。状态行包含协议版本、状态码和状态码的文本描述,例如HTTP/1.1 200 OK,表示请求成功。响应报头包含了服务器可能提供的额外信息,例如服务器的类型、响应内容的长度、日期等。 HTTP消息报头的分类包括普通报头、请求报头、响应报头和实体报头。普通报头适用于请求和响应消息,而请求报头和响应报头只适用于请求或响应消息。实体报头包含与实体主题相关的元数据,如内容类型、内容长度等。 使用telnet可以观察HTTP协议的通信过程,这对于理解HTTP协议的实际工作方式非常有帮助。通过telnet建立连接并发送HTTP请求,可以观察到客户端和服务器之间交换的数据包。 HTTP协议相关技术补充部分涉及了基础概念、协议分析的优势、HTTP协议的安全漏洞以及基于HTTP特性的一些攻击构思。例如,HTTP分析器可以用来检测网络攻击,HTTP协议的Content-Length限制漏洞可能被利用造成拒绝服务攻击。此外,还介绍了Http指纹识别技术,这是一项识别Web服务器的技术,可以用来了解目标服务器的软硬件配置。 整体而言,HTTP协议作为互联网基础技术之一,在Web开发和网络通信领域发挥着关键作用。随着技术的发展,HTTP协议也在不断演进,如HTTP/1.1引入了持续连接机制,而HTTP-NG则是对未来HTTP协议发展方向的建议。了解和掌握HTTP协议的细节对于网络工程师、Web开发者以及安全研究人员等IT专业人员来说至关重要。
- yy_shuguang2015-09-08一本不错的电子书。很有帮助
- 粉丝: 34
- 资源: 45
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助