学Http协议

简介:
(1) 基本概念
HTTP HyperTextTransferProtocol )是超文本传输协议的缩写,它用于传  WWW 方式的数据。HTTP 协议采用了请求/ 响应模型。客户端向服务器发送一个请求,请求头包含请求的方法、URI 、协议版本、以及包含请求修饰符、客户信息和内容的类似于MIME 的消息结构。服务器以一个状态行作为响应,相应的内容包括消息协议的版本,成功或者错误编码加上包含服务器信息、实体元信息以及可能的实体内容。
[ 我来分析]
在这一部分上说的的确很抽象,出现了很多专业名词,只要大家耐心的将其看完就能基本明白这里说的东西了。
如:这一个请求头中就有GET 方法,URI HTTP/1.1 的协议版本还有客户端的相关信息,如User-Agent 指出浏览器的类型(客户端的信息)还有Accept 可以接受的MIME……
如:响应头就包含消息协议的版本,如HTTP/1.1, 状态代码为200 ,以及服务器相关信息如:Microsoft-IIS/5.0…..
大家继续 ……
[ 结束]

通常HTTP 消息包括客户机向服务器的请求消息和服务器向客户机的响应消息。这两种类型的消息由一个起始行,一个或者多个头域组成。 HTTP 的头域包括通用头,请求头,响应头和实体头四个部分 每个头域由一个域名,冒号(: )和域值三部分组成。 域名是大小写无关的,域值前可以添加任何数量的空格符,头域可以被扩展为多行,在每行开始处,使用至少一个空格或制表符。
[ 我来分析]
记住这两种类型的格式和每个头域的格式都是一致的,还有这里提到的几个头域,要知道它们的关系,在这里我用一张“关系图”表示出来了。在下面的资料中,这种关系还会体现出来的。
 

[ 结束]
接下来,我们要对每个头域进行学习了…… 加油,小伙子们……..Come .!
(2) 通用头域
通用头域包含请求和响应消息都支持的头域,通用头域包含Cache-Control Connection Date Pragma Transfer-Encoding Upgrade Via 对通用头域的扩展要求通讯双方都支持此扩展,如果存在不支持的通用头域,一般将会作为实体头域处理。
[ 我来分析]
一开始就提出了: 通用头域包含请求和响应消息都支持的头域”  看来通用头域是包含在请求头域和响应头域中了。但它的要求绝对很高,因为它要求请求头域和响应头域都支持,才可以使用,而不能被两个都支持的则沦为实体头域中了。。。。。。。
[ 结束]
下面简单介绍几个在UPnP 消息中使用的通用头域。
Cache-Control 头域
Cache-Control
指定请求和响应遵循的缓存机制。
在请求消息或响应消息中设置Cache-Control 并不会修改另一个消息处理过程中的缓存处理过程。请求时的缓存指令包括no-cache no-store max-age max-stale min-fresh only-if-cached ,响应消息中的指令包括public  private no-cache no-store no-transform must-r.idate proxy-r.idate  max-age 。各个消息中的指令含义如下:
(1)Public
指示响应可被任何缓存区缓存。
(2)Private
指示对于单个用户的整个或部分响应消息,不能被共享缓存处理。这允许服务器仅仅描述当用户的部分响应消息,此响应消息对于其他用户的请求无效。
(3)no-cache
指示请求或响应消息不能缓存
(4)no-store
用于防止重要的信息被无意的发布。在请求消息中发送将使得请求和响应消息都不使用缓存。
(5)max-age
指示客户机可以接收生存期不大于指定时间(以秒为单位)的响应。
(6)min-fresh
指示客户机可以接收响应时间小于当前时间加上指定时间的响应。
(7)max-stale
指示客户机可以接收超出超时期间的响应消息。如果指定max-stale 消息的值,那么客户机可以接收超出超时期指定值之内的响应消息。
Date
头域
Date
头域表示消息发送的时间 ,时间的描述格式由rfc822 定义。例如,Date:Mon,31Dec200104:25:57GMT Date 描述的时间表示世界标准时,换算成本地时间,需要知道用户所在的时区。
Pragma
头域
Pragma
头域用来包含实现特定的指令,最常用的是Pragma:no-cache HTTP/1.1 协议中,它的含义和Cache-Control:no-cache 相同。
[ 我来分析]
首先这些头域在请求头域和响应头域下都是可以用的。读了下,感觉都说的很清楚了,Cache-control 这部分是很有用的,主要用在响应消息中。大家可以在自己的程序上试验一把( 不过一般我会在Apache mod_expires 模块,或者用squid 。不过,这些不在我这课的范围,哈哈!) 。贴个meta 的资料。(个人觉得这部分还是很有用的,就都COPY 下来了。。。。。。HOHO
 
meta 是用来在 HTML 文档中模拟 HTTP 协议的响应头报文。 meta    标签用于网页的< head >与< /head >中, meta    标签的用处很多。 meta    的属性有两种: name http-equiv name 属性主要用于描述网页,对应于 content (网页内容),以便于搜索引擎机器人查找、分类(目前几乎所有的搜索引擎都使用网上机器人自动查找 meta 值来给网页分类)。这其中最重要的是 de.ion (站点在搜索引擎上的描述)和 keywords (分类关键词),所以应该给每页加一个 meta 值。比较常用的有以下几个:      
     
   name    属性    
     
   1 、< meta   name="Generator"   content="" >用以说明生成工具(如 Microsoft   FrontPage   4.0 )等;    
     
   2 、< meta   name="KEYWords"   content="" >向搜索引擎说明你的网页的关键词;    
     
   3 、< meta   name="DE.ion"   content="" >告诉搜索引擎你的站点的主要内容;    
     
   4 、< meta   name="Author"   content=" 你的姓名 " >告诉搜索引擎你的站点的制作的作者;    
     
   5 、< meta   name="Robots"   content="all|none|index|noindex|follow|nofollow"    
     
  其中的属性说明如下:    
     
  设定为 all :文件将被检索,且页面上的链接可以被查询;    
     
  设定为 none :文件将不被检索,且页面上的链接不可以被查询;    
     
  设定为 index :文件将被检索;    
     
  设定为 follow :页面上的链接可以被查询;    
     
  设定为 noindex :文件将不被检索,但页面上的链接可以被查询;    
     
  设定为 nofollow :文件将不被检索,页面上的链接可以被查询。    
     
   http-equiv 属性    
     
   1 、< meta   http-equiv="Content-Type"   content="text/html";charset=gb_2312-80"    
     
  和     meta   http-equiv="Content-Language"   content="zh-CN" >用以说明主页制作所使用的文字以及语言;    
     
  又如英文是 ISO-8859-1 字符集,还有 BIG5 utf-8 shift-Jis Euc Koi8-2 等字符集;        2 、< meta   http-equiv="Refresh"   content="n;url=http://yourlink" >定时让网页在指定的时间 n 内,跳转到页面 http;//yourlink    
     
   3 、< meta   http-equiv="Expires"   content="Mon,12   May   2001   00:20:00   GMT" >可以用于设定网页的到期时间,一旦过期则必须到服务器上重新调用。需要注意的是必须使用 GMT 时间格式;    
     
   4 、< meta   http-equiv="Pragma"   content="no-cache" >是用于设定禁止浏览器从本地机的缓存中调阅页面内容,设定后一旦离开网页就无法从 Cache 中再调出;
  <meta   http-equiv="Cache-Control"   CONTENT="no-cache">  
     
   5 、< meta   http-equiv="set-cookie"   content="Mon,12   May   2001   00:20:00   GMT" cookie 设定,如果网页过期,存盘的 cookie 将被删除。需要注意的也是必须使用 GMT 时间格式;    
     
   6 、< meta   http-equiv="Pics-label"   content="" >网页等级评定,在 IE internet 选项中有一项内容设置,可以防止浏览一些受限制的网站,而网站的限制级别就是通过 meta 属性来设置的;    
     
   7 、< meta   http-equiv="windows-Target"   content="_top" >强制页面在当前窗口中以独立页面显示,可以防止自己的网页被别人当作一个 frame 页调用;    
     
   8 、< meta   http-equiv="Page-Enter"   content="revealTrans(duration=10,transtion=50)" >和< meta   http-equiv="Page-Exit"   contect="revealTrans(duration=20 transtion=6)" >设定进入和离开页面时的特殊效果,这个功能即 FrontPage 中的 格式 / 网页过渡 ,不过所加的页面不能够是一个 frame 页面。
补充资料
网页的缓存是由 HTTP 消息头中的 “Cache-control” 来控制的,常见的取值有 private no-cache max-age 等,默认为 private 。其作用根据不同的重新浏览方式分为以下几种情况:
1   打开新窗口
如果指定 cache-control 的值为 private no-cache ,那么打开新窗口访问时都会重新访问服务器。而如果指定了 max-age 值,那么在此值内的时间里就不会重新访问服务器,例如:
Cache-control: max-age=5
表示当访问此网页后的 5 秒内再次访问不会去服务器
2   在地址栏回车
如果值为 private ,则只有第一次访问时会访问服务器,以后就不再访问。如果值为 no-cache ,那么每次都会访问。如果值为 max-age ,则在过期之前不会重复访问。
3   按后退按扭
如果值为 private max-age ,则不会重访问,而如果为 no-cache ,则每次都重复访问
4   按刷新按扭
无论为何值,都会重复访问
[ 结束]
3 )请求头域
请求消息的第一行为下面的格式:
Method
 SP  Request-URI  SP  HTTP-Version  CRLF  
Method
表示对于Request-URI 完成的方法 ,这个字段是大小写敏感的,包括OPTIONS GET HEAD POST PUT DELETE TRACE 方法GET HEAD 应该被所有的通用WEB 服务器支持,其他所有方法的实现是可选的。 GET 方法 取回由Request-URI 标识的信息。HEAD 方法也是取回由Request-URI 标识的信息,只是可以在响应时,不返回消息体。 POST 方法 可以请求服务器接收包含在请求中的实体信息,可以用于提交表单,向新闻组、BBS 、邮件群组和数据库发送消息。
SP
表示空格
Request-URI
遵循URI 格式 ,在此字段为星号(* )时,说明请求并不用于某个特定的资源地址,而是用于服务器本身。
HTTP-Version
表示支持的HTTP 版本 ,例如为HTTP/1.1
CRLF
表示换行回车符。
请求头域允许客户端向服务器传递关于请求或者关于客户机的附加信息。请求头域可能包含下列字段Accept Accept-Charset Accept- Encoding Accept-Language Authorization From Host If-Modified-Since If- Match If-None-Match If-Range If-Range If-Unmodified-Since Max-Forwards  Proxy-Authorization Range Referer User-Agent 对请求头域的扩展要求通讯双方都支持,如果存在不支持的请求头域,一般将会作为实体头域处理。
典型的请求消息:
GET[url]http://class/download.microtool.de:80/somedata.exe[/url]
Host:download.microtool.de
Accept:*/*
Pragma:no-cache
Cache-Control:no-cache
Referer:[url]http://class/download.microtool.de/[/url]
User-Agent:Mozilla/4.04[en](Win95;I;Nav)
Range:bytes=554554-
上例第一行表示HTTP 客户端(可能是浏览器、下载程序)通过GET 方法获得指定URL 下的文件。
Host
头域
Host
头域指定请求资源的Intenet 主机和端口号,必须表示请求url 的原始服务器或网关的位置 HTTP/1.1 请求必须包含主机头域,否则系统会以400 状态码返回。
Referer
头域
Referer
头域允许客户端指定请求uri 的源资源地址,这可以允许服务器生成回退链表 ,可用来登陆、优化cache 等。他也允许废除的或错误的连接由于维护的目的被追踪。如果请求的uri 没有自己的uri 地址,Referer 不能被发送。如果指定的是部分uri 地址,则此地址应该是一个相对地址。
Range
头域
Range
头域可以请求实体的一个或者多个子范围 。例如,
表示头500 个字节:bytes=0-499
表示第二个500 字节:bytes=500-999
表示最后500 个字节:bytes=-500
表示500 字节以后的范围:bytes=500-
第一个和最后一个字节:bytes=0-0,-1
同时指定几个范围:bytes=500-600,601-999
但是服务器可以忽略此请求头,如果无条件GET 包含Range 请求头,响应会以状态码206 PartialContent )返回而不是以200 OK )。
User-Agent
头域
User-Agent
头域的内容包含发出请求的用户信息。
[ 我来分析]
这一部分是请求头信息,大家需要多用些HTTP 分析工具去浏览些网站来对比学习,给大家推荐两款软件,一款是IE 支持的HTTPWATCH ,另一款是firefox httpfox 插件.
[ 结束]
(4) 响应头信息
响应消息的第一行为下面的格式:
HTTP-Version
 SP  Status-Code  SP  Reason-Phrase  CRLF
HTTP-Version
表示支持的HTTP 版本 ,例如为HTTP/1.1
Status-Code
是一个三个数字的结果代码
Reason-Phrase
Status-Code 提供一个简单的文本描述 Status-Code 主要用于机器自动识别,Reason-Phrase 主要用于帮助用户理解。Status-Code 的第一个数字定义响应的类别,后两个数字没有分类的作用 。第一个数字可能取5 个不同的值:
1xx:
信息响应类,表示接收到请求并且继续处理
2xx:
处理成功响应类,表示动作被成功接收、理解和接受
3xx:
重定向响应类,为了完成指定的动作,必须接受进一步处理
4xx:
客户端错误,客户请求包含语法错误或者是不能正确执行
5xx:
服务端错误,服务器不能正确执行一个正确的请求
  应头域允许服务器传递不能放在状态行的附加信息,这些域主要描述服务器的信息和Request-URI 进一步的信息。响应头域包含Age  Location Proxy-Authenticate Public Retry-After Server Vary Warning WWW- Authenticate 对响应头域的扩展要求通讯双方都支持,如果存在不支持的响应头域,一般将会作为实体头域处理。
典型的响应消息:
HTTP/1.0200OK
Date:Mon,31Dec200104:25:57GMT
Server:Apache/1.3.14(Unix)
Content-type:text/html
Last-modified:Tue,17Apr200106:46:28GMT
Etag:"a030f020ac7c01:1e9f"
Content-length:39725426
Content-range:bytes554554-40279979/40279980
上例第一行表示HTTP 服务端响应一个GET 方法。棕色的部分表示响应头域的信息,绿色的部分表示通用头部分,红色的部分表示实体头域的信息。
Location
响应头
Location
响应头用于重定向接收者到一个新URI 地址。
Server
响应头
Server
响应头包含处理请求的原始服务器的软件信息 。此域能包含多个产品标识和注释,产品标识一般按照重要性排序。
(5) 实体头域
请求消息和响应消息都可以包含实体信息, 实体信息一般由实体头域和实体组成。 实体头域包含关于实体的原信息,实体头包括Allow Content-Base Content-Encoding Content-Language  Content-Length Content-Location Content-MD5 Content-Range Content-Type  Etag Expires Last-Modified extension-header extension-header 允许客户端定义新的实体头,但是这些域可能无法未接受方识别。实体可以是一个经过编码的字节流,它的编码方式由Content-Encoding Content-Type 定义,它的长度由Content-Length Content-Range 定义。
Content-Type
实体头
Content-Type 
实体头用于向接收方指示实体的介质类型 ,指定HEAD 方法送到接收方的实体介质类型,或GET 方法发送的请求介质类型Content-Range 实体头
Content-Range
实体头
用于指定整个实体中的一部分的插入位置,他也指示了整个实体的长度 。在服务器向客户返回一个部分响应,它必须描述响应覆盖的范围和整个实体长度。一般格式:
Content-Range:bytes-unit
 SP  first-byte-pos - last-byte-pos/entity-legth
  如,传送头500 个字节次字段的形式:Content-Range:bytes0-499/1234 如果一个http 消息包含此节(例如,对范围请求的响  应或对一系列范围的重叠请求),Content-Range 表示传送的范围,Content-Length 表示实际传送的字节数。
Last-modified 实体头
Last-modified
实体头指定服务器上保存内容的最后修订时间。
[ 我来分析]
我觉得从请求头信息,响应头信息,还有现在的实体头域上面说到的这些都是一些特有的,大家需要的不是强行记忆,而是多加练习分析,以达到记住,唉,我就是差这个,这篇文章都看了好几遍了,可现在还要拿出来看。以后,没事做浏览网站就学学。。。。。。HOHO
[ 结束]
[ 总结 ] 我们将其学习完,并不是说我们就完全掌握了,这才是刚刚开始,我们只是懂了点 HTTP 的一角,我们还需要在以后多多练习,多多分析,掌握了这门知识在以后学习 squid ,还有些其他的 web 服务器上配置上是有一定的好处的。大家一起学习吧 ! 这份资料,我以后还会陆续修改添加的。。。


这是一篇结合网上的教程写的,希望对大家学习有帮助!如果牵涉到版权问题,请告诉我,我会及时处理的。谢谢!


本文转自hahazhu0634 51CTO博客,原文链接:http://blog.51cto.com/5ydycm/126893,如需转载请自行联系原作者
相关文章
|
16天前
|
网络协议 Linux iOS开发
推荐:实现RTSP/RTMP/HLS/HTTP协议的轻量级流媒体框架,支持大并发连接请求
推荐:实现RTSP/RTMP/HLS/HTTP协议的轻量级流媒体框架,支持大并发连接请求
38 1
|
1月前
|
网络协议 Linux
HTTP协议基本原理简介(二)
HTTP协议基本原理简介(二)
23 1
|
1月前
|
前端开发
webpack如何设置devServer启动项目为https协议
webpack如何设置devServer启动项目为https协议
135 0
|
2月前
|
安全 前端开发 网络协议
|
1月前
|
缓存 前端开发
HTTP协议基本原理简介(三)
HTTP协议基本原理简介(三)
14 1
|
1天前
|
网络协议 Java API
深度剖析:Java网络编程中的TCP/IP与HTTP协议实践
【4月更文挑战第17天】Java网络编程重在TCP/IP和HTTP协议的应用。TCP提供可靠数据传输,通过Socket和ServerSocket实现;HTTP用于Web服务,常借助HttpURLConnection或Apache HttpClient。两者结合,构成网络服务基础。Java有多种高级API和框架(如Netty、Spring Boot)简化开发,助力高效、高并发的网络通信。
|
4天前
|
缓存 安全 网络协议
Http协议是什么
【4月更文挑战第12天】HTTP是用于从WWW服务器传输超文本到浏览器的协议,基于TCP/IP,特点包括无连接、无状态、面向对象、无阻塞和可缓存。它的工作原理是客户端发送请求,服务器处理后返回响应。自1989年创建以来,HTTP已发展支持多媒体内容传输,并通过HTTPS提供安全保护。学习更多可参考计算机网络技术文献。
15 6
|
6天前
|
存储 JSON 前端开发
网络原理(4)HTTP协议(下)
网络原理(4)HTTP协议
19 0
|
16天前
|
XML JSON JavaScript
推荐一个比较好用的c++版本http协议库-cpp-httplib
推荐一个比较好用的c++版本http协议库-cpp-httplib
36 1
|
23天前
|
运维 监控 算法
slb监听协议http
SLB的HTTP监听器用于处理HTTP请求,配置时选择协议类型为HTTP和前端端口(如80)。SLB根据负载算法将请求转发至健康后端服务器,并支持会话保持。通过`X-Forwarded-For`和`X-Forwarded-Proto`头处理请求信息。由于不涉及SSL/TLS,数据传输不安全,推荐升级至HTTPS以加密通信。SLB提供性能监控和故障排查工具,帮助运维管理。
21 5