43tt 发表于 2014-5-12 11:37:09

httpd一之关于http工作模式的基本说明

本文主要讲解http的协议版本、http报文、http的首部以及一个web请求的基本过程等相关概念性问题
本文中主要用到一些名词解释
http hyprttext transport protcol 超文本传输协议
html hypertext mark language 超文本标记语言
URI:Uniform Resource Identifier 统一资源提示符
URL: Uniform Resource Locator 统一资源定位符
一、HTTP协议的版本:
   http0.9:只能传输html文档
   http1.0:支持多媒体数据的处理,保持连接。有缓存功能
   http1.1:支持更多的请求方法,更加精细的缓存控制,能保持持久连接
二、HTTP报文格式
    1)HTTP事务
       一次请求与其对应的响应,称之为HTTP的事务
    2)HTTP请求的方法
       GET:请求获取一个资源,需要服务器发送给客户端
       HEAD:跟GET相似,但其不需要服务器发回资源仅传回响应首部即可
       POST:支持HTML表单提交,表单中有用户填入的数据,这些数据会发送到服务器端,由服务器存储至某个位置,也可能是发送给某个处理程序进行处理
       PUT:与GET相反,是向服务器写入文档,如发布系统
       DELETE:请求删除URL指向的资源
       OPTIONS:探测服务器端对某资源所支持的请求方法
       TRACE:用于追踪请求资源要经过的防火墙、代理或网关等
      其中GET、HEAD为比较安全的请求方法,PUT、DELETE为相对不安全的方法
    3)响应报文代码(此处只有一些常用的代码)
       1XX:信息性状态码
       2XX: 成功状态码
         200:表示访问OK
         201:Created OK 写入成功
       3XX: 重定向状态码
         301:Moved Permanebtly 永久重定向,在响应报文中使用“Location:URL”来指定资源现在所在的位置
         302:Found 临时重定向,在响应报文中使用“Location:URL”来指定资源临时所在的位置
      4XX:客户端的错误
         403:Forbidden 请求被服务器拒绝
         404:Not Fonud 服务器无法找到请求的URL
         405:Method Not Allowed 不允许使用此方法请求响应的URL
      5XX:服务器类的错误
         500:Internal Server Error 服务器内部错误
         502:Bad Gateway 代理服务器上游收到一条伪响应
         503:Service Unavailable 服务器此时无法提供服务,但将来可能可用
   4)HTTP首部
      通用首部:请求和响应都可以使用的
            Connection:定义c/s之间关于请求/响应的有关选项,例如,对于HTTP/1.0可以使用 Connection keep-alibe
            Via:显示了报文中经过的中间节点
            Cache-Control:缓存指示,常用于缓存服务器
      请求首部:只能请求时使用的
         报文格式:
         <method><request-url><version>
         <headers>
         <entity-body>
            <method>:请求方法,希望服务器端执行的动作,如GET、HEAD、POST等
            <request-url>:请求的资源,可以是相对路径,也可以是完整的URL
            <version>:协议版本,格式HTTP/<major>。<minor>,如http/1.0
            <headers>:HTTP首部
            选项
            Cilent-IP:请求端ip
            Host:请求的主机名和端口号,虚拟主机环境下用于不同的虚拟主机
            Referer:指明了请求当前资源的原始资源URL
            User-Agent:用户代理,使用什么工具发出的请求
            Accept首部:用户标明客户自己更倾向于支持使用的能力
               Accept:指明服务器能发送的媒体类型
               Accept-Charset:支持使用的字符集
               Accept-Encoding:支持使用的编码方式
               Accept-Language:支持使用的语言
            请求条件首部
               Expect:期望的服务器端的行为
               If-Modified-Since:是否在指定的时间以来修改过此资源
               If-None-Match:如果提供的实体标记与当前的实体标记不相符,则获取文件
            跟安全相关的请求首部
               Authorication:客户端提交给服务端的认证数据,如账号和密码
               Cookie:客户端发送给服务器端的身份标识,还有高级版本Cookie2
      响应首部:只能响应时使用的
         报文格式:
         <version><status><reason-phrase>
         <headers>
         <entity-body>
         <status>:状态码
         <reason-phrase>:原因短语,数字状态吗易读信息
         <entity-body>:主体部分
          选项
         Age:响应持续的时间
         Server:向客户端标明服务器程序名称和版本
         协商首部:
            Accept-Ranges:对当前资源来讲,服务器所能够接受的范围类型
            Vary:首部列表,服务器会根据列表中的内容挑选出最适合的版本发送给客户端
         跟安全相关的响应首部
            Set-Cookie:服务器端在某客户端第一次请求时发给客户端的令牌,还有高级版本Set-Cookie2
            WWW-Authenication:质询,即要求客户端提供账号和密码
      实体首部:用于指定实体属性
            Location:资源的新位置
            Allow:允许对此资源使用的请求方法
            内容首部:
               Contern-Encoding 返回的编码方式
               Contern-Language 返回的语言
               Contern-Length   放回的长度
               Contern-type   主体对象的类型
               Contern-Range 表示的主体的字节范围
               Contern-Location 资源主体所在的位置
      扩展首部:非标准首部,可能是由程序开发者创建的
三、一个web请求的基本过程
   建立请求
   接受请求
   处理请求
   访问资源
   构建响应
   发送响应
   记录日志

页: [1]
查看完整版本: httpd一之关于http工作模式的基本说明