HTTP协议详解



HTTP协议概述

1、TCP/IP是个协议组,可分为三个层次:网络层、传输层和应用层。
在网络层有IP协议、ICMP协议、ARP协议(地址解析协议)、RARP协议(反向地址转换协议)。
在传输层中有TCP协议与UDP协议。
在应用层有FTP、HTTP、TELNET、SMTP、DNS等协议。
因此,HTTP本身就是一个协议,是从Web服务器传输超文本到本地浏览器的传送协议,是超文本传输协议。


2、 HTTP协议是建立在请求/响应模型上的。首先由客户建立一条与服务器的TCP链接,并发送一个请求到服务器,请求中包含请求方法、URI、协议版本以及 相关的MIME样式的消息。服务器响应一个状态行,包含消息的协议版本、一个成功和失败码以及相关的MIME式样的消息。
HTTP/1.0为每一次HTTP的请求/响应建立一条新的TCP链接,因此一个包含HTML内容和图片的页面将需要建立多次的短期的TCP链接。一次TCP链接的建立将需要3次握手。
另 外,为了获得适当的传输速度,则需要TCP花费额外的回路链接时间(RTT)。每一次链接的建立需要这种经常性的开销,而其并不带有实际有用的数据,只是 保证链接的可靠性,因此HTTP/1.1提出了可持续链接的实现方法。HTTP/1.1将只建立一次TCP的链接而重复地使用它传输一系列的请求/响应消 息,因此减少了链接建立的次数和经常性的链接开销。

3、结论:虽然HTTP本身是一个协议,但其最终还是基于TCP的。不过,目前,有人正在研究基于TCP+UDP混合的HTTP协议。


补充:

ARP协议(地址解析协议):设备通过自己知道的IP地址来获得自己不知道的物理地址的协议

    RARP协议(反向地址转换协议):设备通过自己知道的物理地址来获得自己不知道的IP地址的协议

    ICMP协议(控制报文协议):用于在IP主机、路由器之间传递控制消息。控制消息是指网络通不通、主机是否可达、路由是否可                                                             用等网络本身的消息、

    IP协议:此协议负责调用本地网络协议将数据包传送以下一个网关或目的主机

    

    TCP协议(传输控制协议):一种面向连接的、可靠的、基于字节流的传输层通信协议

    UDP协议(用户数据报协议):一种无连接的、不可靠的、基于数据包的传输层通信协议

    

     FTP协议(文件传输协议):用于Internet上的控制文件的双向传输

    SMTP协议(简单邮件传输协议):一种TCP协议支持的提供可靠且有效电子邮件传输的应用层协议

    DNS(域名系统):把地址映射为名字或把名字映射成地址时要调用解析程序

  

HTTP协议的主要特点:

http(超文本传输协议)是一个基于请求与响应模式的、无状态的、应用层的协议,常基于TCP的连接方式,HTTP1.1版本中给出一种持续连接的机制


HTTP URL: 
http://host[":"port][abs_path] 
http表示要通过HTTP协议来定位网络资源;host表示合法的Internet主机域名或者IP地址;port指定一个端口号,为空则使用缺省端口80;abs_path指定请求资源的URI;


HTTP请求

 http请求由三部分组成,分别是:请求行、消息报头、请求正文

Method      Request-URI       HTTP-Version,其中 Method表示请求方法;Request-URI是一个统一资源标识符;HTTP-Version表示请求的HTTP协议版本。

请求方法(所有方法全为大写)有多种,各个方法的解释如下: 
GET    请求获取Request-URI所标识的资源 
POST    在Request-URI所标识的资源后附加新的数据 
HEAD   请求获取由Request-URI所标识的资源的响应消息报头 
PUT     请求服务器存储一个资源,并用Request-URI作为其标识 
DELETE  请求服务器删除Request-URI所标识的资源

HTTP响应

在接收和解释请求消息后,服务器返回一个HTTP响应消息。HTTP响应也是由三个部分组成,分别是:状态行、消息报头、响应正文

1、状态行格式如下: 
HTTP-Version     Status-Code       Reason-Phrase 
其中,HTTP-Version表示服务器HTTP协议的版本;

Status-Code表示服务器发回的响应状态代码;

Reason-Phrase表示状态代码的文本描述。 


1、状态行格式如下: 
HTTP-Version Status-Code Reason-Phrase CRLF 
其中,HTTP-Version表示服务器HTTP协议的版本;Status-Code表示服务器发回的响应状态代码;Reason-Phrase表示状态代码的文本描述。 
状态代码有三位数字组成,第一个数字定义了响应的类别,且有五种可能取值: 
1xx:指示信息--表示请求已接收,继续处理 
2xx:成功--表示请求已被成功接收、理解、接受 
3xx:重定向--要完成请求必须进行更进一步的操作 
4xx:客户端错误--请求有语法错误或请求无法实现 
5xx:服务器端错误--服务器未能实现合法的请求 
常见状态代码、状态描述、说明: 
200 OK      //客户端请求成功 
400 Bad Request  //客户端请求有 语法错误 ,不能被服务器所理解 
401 Unauthorized // 请求未经授权 ,这个状态代码必须和WWW-Authenticate报头域一起使用  
403 Forbidden  //服务器收到请求,但是 拒绝提供服务  
404 Not Found  // 请求资源不存在 ,eg:输入了错误的URL 
500 Internal Server Error //服务器发生不可预期的错误 
503 Server Unavailable  //服务器当前不能处理客户端的请求,一段时间后


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值