• 4、http协议之二


    URL(Unifrom Resource Locator)简述

    相对URL 从当前页面(同一个站点内或同一个文章内引用)

    绝对URL 从当前页面或其他页面跳转而来(跨站引用)

    HTTPD版本<0.9文本><1.0,method,mime,弱缓存><1.1持久连接><2.0,mime,spdy,缓存,method>

    HTTPD特性:无状态、文本编码协议<telnet, curl, enlinks>

    追踪用户来源的机制:cookie(重cookie,轻cookie),session

    Cookie分类

    Cookie工作机制: 随机数惟一标识用户

    轻cookie应用: 数据结构保存cookie与session的映射

    100信息

    200 OK 成功

    301 Moved Permantly 永久 302 Found 临时 304 Not Modified 条件

    401 WWW-Authenticate 质询认证   403 Forbidden 没有权限访问  404 Not Found 没有资源 

    500 Internal Server Error 服务内部错误    502 Bad Gateway 错误网关

    一、URL 

    Uniform Resource Locator 标识每个资源的位置 URL是URI的子集

    wKiom1nJ-RDgjRdhAAA-u68AC_I008.png

    wKioL1nJ-NXS1xyJAACC9wLjBC8129.png

    相对URL:相对当前页面的URL,(相对路径:由当前工作目录起始的路径)

    绝对URL:用于跨站引用或当前页面,(绝对路径:由/起始的路径)

    二、HTTPD版本 

    wKioL1nJ-bWwnqnDAAAszbo6oXQ354.png

    2.1、HTTPD特性

    • http stateless 无状态 服务器无法持续追踪访问者来源
    • 文本编码协议

    2.2、追踪用户来源的机制

      动态站点中用来追踪并保存用户浏览行为的或访问行为的重要机制:Cookie ,session

    2.2.1、Cookie工作方式(相当于第一次访问某服务器时候,此service发给client的令牌)

    wKioL1nJ_W-j4nQ2AADisY5AgIA700.png

      二次通信: 

      服务器 接收随机数(令牌) <-- 客户端  将访问的服务器首次所发的令牌发给服务器,用于标明自己的身份

    2.2.2、Cookie分类

      重cookie:有可能会泄露用户隐私

      轻cookie:只记录少量的信息

          免费的杀毒软件,可以获取磁盘底层的信息最高权限,有的放矢的投放广告

    2.2.3、Session:<轻cookie:减小隐私信息丢失的可能性>,在服务器端在进程内存中维护Session

    wKioL1nKACzjB7cDAAAprAAb4BM891.png

    2.3、HTTP事务 

      一次httpd请求request对应一次响应respone,即为事务

      事务元数据:(起始行+headers)

      实体:entity-body部分

    HTTP请求响应报文详解

    wKioL1nKCjmBW5eAAAAM3N4-Lu8364.png

    2.3.1、请求报文语法

    <method> <requeset-url> <version>    请求报文http首部---请求行
    <header>                  首部
    换行1
    换行2
    <entity-body> 请求的主体内容

    2.3.2、响应报文语法

    <version> <status> <reason-phrase>;响应的原因
    <header>
    换行1
    换行2
    <entity-body>

    2.3.3、method 请求方法,标明客户端希望服务器端对资源执行的动作(客户端告诉服务器做什么)

     

    wKiom1nKBaGj_rUIAAAcdYi6Clg457.png

     

    wKioL1nK_hzSRk8zAAB6IST_l6w385.png

       

     POST 向服务器发送要处理的数据,请求实体不为空  (危险)

     PUT  将请求的主体部分存储在服务器上,请求实体不为空 (非常危险)

     DELETE 请求删除服务器上,通过URL指定的文档 (更危险)

     

    wKioL1nKBdHyvTomAAA8r275sOE884.png

    2.3.4、status code 服务器告诉客户端结果   统一三位数字,原因短语---标记请求过程中所发生的情况

    常用的状态码:

      200 :成功,请求的所有数据通过响应报文的entity-body部分发送: OK

      301:请求的URL指向的资源已经被删除;但在响应报文中通过首部Location指明了资源现在所处的新位置:Moved Permanently

      302:与301相似,但是在响应报文中通过Location指明资源现在所处临时新位置;Found

      304:客户端发生了条件式请求,但服务器上的资源未曾发生改变,则通过响应此响应状态码通知客户端:Not Modified

      401:需要输入账号和密码认证方能访问资源:Unauthorized

      403:请求被禁止:Forbidden

      404:服务器无法找到客户端请求的资源:Not Found

      500:服务器内部错误:Internal Server Error

      502:代理服务器从后端服务器收到一条伪响应 :Bad Gateway

    wKioL1nKCfnDMJQ7AAA7gHUxIlc298.png

    2.3.5、reason-phrase   原因短语 状态码标记的状态简要描述

    2.3.6、 headers 首部------用来标记请求或响应的属性

    headers 请求和响应首部: 标记请求或响应的属性 , 事务交换的元数据信息

    负载均衡调度时,可以根据首部调度

    1、首部可以有多个

    2、首部的格式:Directive: value

          每个请求或响应报文可包含任意个首部;每个首部都有首部名称,后面跟一个冒号,而后跟上一个可选空格,接着是一个值;

    首部的分类:

    • 通用首部:(既可以用在请求报文或者响应报文首部中)
      • Date :报文的创建时间
      • Connection:表示是否需要持久连接状态,如http1.1默认进行keep-alive,close
      • Via :显示报文经过的中间节点
      • Transfer-Encoding:规定了传输报文主体时采用的编码方式
      • Cache-Control : 控制缓存
        • no-cache:先发送请求,与服务器确认该资源是否被更改,如果未被更改,则使用缓存。
        • no-store:不允许缓存,每次都要去服务器上,下载完整的响应。
        • public:缓存所有的响应(提高了响应速度,但是对存储空间的利用率很低)
        • private:只为单个用户缓存,不允许任何中继进行缓存(比如CDN(分发网络)就不能缓存这种规定下的响应)
        • max-age: 表示当前请求开始,该响应在多久内能被缓存和重用。例如:max-age=60表示响应可以再缓存和重用 60 秒。
      • Pragma :兼容HTTP/1.0或HTTP/1.1
    • 请求首部(自己可接受的特性)
      • Accept :通知服务器能自己可接受的媒体类型
      • Accept-Charset : 接受字符集类型
      • Accept-Encoding :接受哪种编码压缩格式,如:gzip, deflate, br
      • Accept-Language:接受的语言
      • Host:  请求的服务器名称和端口号
          blog.51cto.com
      • Referer: 包含当前正在请求的资源的上一级资源(访问入口)
          https://blog.51cto.com/sonlich/1968933
      • User-Agent:  客户端代理(即浏览器的类型)
               Mozilla/5.0 (Windows NT 10.0; Win64; x64)
      • 条件式请求首部 (和缓存有关)
        • Expect
        • If-Modified-Since:自从指定的时候之后,请求的资源是否发生过修改
        • If-Unmodified-Since
        • If-None-Match:本地缓存中存储的文档的ETag标签是否与服务器文档的ETag不匹配
        • If-Match:
      • 安全请求首部:
        • Authorization:向服务器发送认证信息,如账号和密码
        • Cookie:客户端向服务器发送cookie
        • Cookie2 version 2
      • 代理请求首部
        • Proxy-Authorization:向代理服务器认证
    • 响应首部
      • 信息性
        • Age :响应持续时长
        • Server:服务器程序软件名和版本
      • 协商首部:某资源有多种表示方法时使用
        • Accept-Ranges :服务器可接受的请求范围类型
        • Vary :服务器查看的其它首部列表
      • 安全响应首部
        • Set-Cookie :向客户端设置cookie
        • Set-Cookie2 版本
        • WWW-Authenticate:来自服务器的对客户端的质询认证表单
    • 实体首部:描述entity-body的信息
      • Allow :列出对此实体可使用的请求方法
      • Location:告诉客户端真正的实体位于何处
      • 内容格式:
        • Content-Encoding :内容的编码格式
        • Content-Language:内容的语言
        • Content-Length:内容的大小
        • Content-Locating:实体真正的位置
        • Content-Type :MIME类型
      • 缓存相关
        • ETag :实体的额外标签,基于标签的条件式请求
        • Expires :实体过期时间
        • Last-Modified :实体最近一次修改的时间
    • 扩展首部:额外添加的首部

    2.3.7、entity-body :实体-----有用的数据块,请求时附加的数据或响应时附加的数据  

    反向代理:将自己扮演为服务端接收请求,支持缓存,拆封报文并重新封装

    正向代理:将自己扮演为客户端发起请求

    重定向

    条件式请求

    wKiom1nKDQDAKVABAAAcrcrqZSY284.png

    用户质询认证

    wKioL1nKEJ_RfY8cAABfRT5vde0430.png

    Forbidden 请求被禁止,IP控制或用户访问控制不通过时

    404 用户请求一个不存在的资源 

    错误网关:

    wKiom1nKCyiwOmz-AAArdZbEuwo524.png

    示例

    General
        Request URL:http://172.16.100.1/          
        Request Method:GET
        Status Code:200 OK
        Remote Address:172.16.100.1:80                   //服务器地址 
    Response Headers
    view source
        Accept-Ranges:bytes                                          
        Connection:close                                 // 服务器是非持久连接 KeepAlive off
        Content-Encoding:gzip                            // 实体格式:字符集,包含多种语言编码格式
        Content-Length:7725                              // 大小
        Content-Type:text/html; charset=UTF-8            // 类型
        Date:Sat, 09 Sep 2017 12:30:15 GMT               // 请求报文的创建时间
        ETag:"10c-6353-558c0da6c3922"                    // 实体的额外标签,基于标签的条件式请求
        Last-Modified:Sat, 09 Sep 2017 12:30:05 GMT      // 实体最近一次修改的时间    
        Server:Apache/2.2.15 (CentOS)                    // 服务器程序名、版本号
        Vary:Accept-Encoding                             // 服务器查看变化的首部
    Request Headers
    view source
        Accept:text/html,application/xhtml+xml,applicat // 客户端可接受的MIME类型
        Accept-Encoding:gzip, deflate, sdch             // 客户端可接受的压缩格式    
        Accept-Charset:                                 // 字符集               
        Accept-Language:zh-CN,zh;q=0.8                  // 客户端可接受的语言编码格式
        Cache-Control:max-age=0                         // 缓存控制
        Connection:keep-alive                           // 
        Host:172.16.100.1                               // 服务器主机                  
        User-Agent:Mozilla/5.0                 // 用户代理
     
  • 相关阅读:
    惊讶
    BLOG休假
    因考试得福
    Shape of My HeartSting !
    一个月的第一天了
    BLOG开张喽~~~
    该走了
    脏话
    EditText的属性
    游戏引擎
  • 原文地址:https://www.cnblogs.com/liuzhiyun/p/11737193.html
Copyright © 2020-2023  润新知