zoukankan      html  css  js  c++  java
  • (一)HTTP协议的一些知识点(来自那些年的笔记)


    目录


    http协议1.0、1.1两个版本的区别

    (具体的在图解HTTP上面有讲)

    区别在于: 1.0版本客户机与web服务器建立连接之后,只能获取一个web资源,获取完一个web资源以后,连接就会被断开 而1.1版本在建立连接之后,则可以获取多个web资源


    访问几次服务器?

    场景:一个web页面中,使用了三个img标签,引用三幅图片;当客户端访问服务器中的这个web页面时,客户端总共会访问几次服务器呢?即向服务器发送几次请求 ;

    答案是4次

    第一次是客户端向服务器要这个web页面;然后服务器将回送一个响应头;这里仅仅是HTML文件,不含有图片等静态资源等图片等静态资源,在HTML里面都是以超链接的形式存在);当客户端的IE浏览器解析HTML文档的时候,遇到img标签的时候,发现是一个静态资源,会根据其超链接,再次向服务器要图片资源;因此,还需要额外的访问3次服务器,加起来一共是四次;
    我们在写web页面的时候,应该尽量减少客户端访问服务器的次数;

    也就是说,浏览器在解析HTML的时候,遇到静态资源,会继续向服务器发送请求


    Http请求行和请求方式详解

    • 什么是http请求

      客户端连上服务器,向服务器请求某个web资源,称之为客户端向服务器发送了一个http请求。

    • 一个完整的http请求包括如下内容:

    一个请求行 GET news/a.html [HTTP/1.1 200 OK 5ms]
    若干个请求头
    Accept text/html,application/xhtml+xm…plication/xml;q=0.9,/;q=0.8
    Accept-Language zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3
    Accept-Encoding gzip, deflate
    Connection keep-alive
    Upgrade-Insecure-Requests 1
    …… ……
    一个空行 ( 这里有一个空行,在请求数据与请求内容之间)
    实体内容 (只有用POST方式提交的数据,才会写在这里)

    • 请求行的细节

      请求方式,现在常用的只有两种:POST 、GET

      默认情况下,浏览器向服务器发送的请求都是GET,比如:直接输入地址访问浏览器、超链接等,都是get;只有使用表单提交数据的时候,才可以改变提交方式为POST ;

    • POST还是GET的区别在于:数据的传递上

      如果请求方式为 GET 形式,则可以在请求的URL地址后面以?的形式带上,准备提交给服务器的数据,多个数据之间以 & 进行分隔;

      例如: GET /mail/1.html?name=abc&pass=xyz HTTP/1.1

      GET请求有个特点:在URL地址后面附带的参数是有限制的,其数据容量通常不能超过 1K

      请求方式为POST方式时:则可以在请求的实体内容中的向服务器发送数据,POST方式传递的数据是无限制的;


    可以在超链接上传一些数据

    可以在点击超链接访问服务器的时候,向服务器提交一些数据;我们在超链接的herf=”2.html?name=allbet” 这样点击,超链接就会访问2.html页面,并且会带些数据传过去;


    HTTP请求头各个头字段的详解

    请求头字段 含义
    Accept : 用于告诉服务器,客户机支持的数据类型
    Accept-Charset: 用于告诉服务器,客户机采用的编码
    Accept-Encoding: 用于告诉服务器,客户机支持的数据压缩格式
    Accept-language: 客户机的语言环境
    Host : 客户机通过这个头告诉服务器,想要访问的主机名
    If-Modified-Since : 客户机通过这个头告诉服务器,资源的缓存时间
    Referer: 客户机通过这个头告诉服务器,它是从哪一个资源来访问服务器的;(防盗链)
    User-Agent: 客户机通过这个头,告诉服务器,客户机的软件环境 ;
    …… …….

    HTTP响应和响应行状态详解

    一个HTTP响应代表服务器向客户端回送的数据,它包括:一个状态行、若干消息头、以及实体内容 ;

    • 常见状态码详解
    状态码 含义
    302: 代表请求的资源已经移动到新的地方,服务器等会还会回送一个localtion,指明新资源的位置 ;
    304、307: 服务器回送这两个状态码,表示让客户端浏览器去寻找缓存 ;
    404: 表示服务器没有这个资源;
    403: 表示访问权限不够
    500: 服务器端出现错误

    断点下载

    HTTP响应头字段——Range,这个字段可以实现断点下载 ;
    

    Range它指示服务器只传输一部分Web资源。这个头可以实现断点续传功能。Range字段可以通过三种格式设置要传输的字节范围:

    Range: bytes=1000-2000
            传输范围为1000到2000字节
    Range:bytes=1000-
            传输web资源中第1000个字节以后的所有内容 ;
    Range   :bytes=1000 
            传输最后1000个字节
    

    HTTP响应头字段详解

    字段 含义
    Localtion 请求重定向;地址栏会发生变化;
    Sever 服务器通过这个头,告诉浏览器,服务器的类型
    Content-Encoding 服务器通过这个头,告诉浏览器,数据的压缩格式
    Content-Length 服务器通过这个头,告诉浏览器,回送的数据长度,压缩数据需要带上这个;
    Content-Type 服务器通过这个头,告诉浏览器,回送的数据的数据类型
    Refresh: 服务器通过这个头,告诉浏览器,隔多久刷新一下
    Content-Dispositon 服务器通过这个头,告诉浏览器,以下载方式打开数据;
    Etag 服务器,为每个web资源生成一个标识符。每次都会随着资源一起返回;浏览器访问服务器的时候,也会带着这个标识符;这个标识符,就是判断服务器端的资源是否更新,为了实时更新数据 ;
    Last-Modified: 服务器通过这个头,告诉浏览器,当前资源的最后更新时间
    Expires: 服务器通过这个头,告诉浏览器把回送的资源缓存多长时间,-1或0表示不缓存 ;
    Accept-Range: 这个字段说明web服务器是否支持Range,支持的话,就返回Accept-Range:bytes ;如果不支持,就返回Accept-Range:none
    Content-Range: 指定了返回Web资源的字节范围,这个字段值的格式是:Content-Range:1000-3000/5000 ; 表示:整个资源一个5000字节,返回的是第1000到3000字节 ;

    Etag 与 Last-Modified 的区别:

    当我们与服务器建立连接以后, 第一次获取一个web资源的时候以后,连接没有断开这时候,web端更新了之前的web数据,这时候浏览器,再次请求这个数据的时候, 由于之前的连接没断开,服务器端不会再做Last-Modified判断;会告诉浏览器,去寻找缓存,这样数据就无法实时更新; 而Etag,每次访问数据都会带着,只要一比对Etag不一样了,就会发现数据需要更新


    关于缓存的字段

    字段 取值
    Expires: -1/0 ,具体毫秒值
    Cache-Control: no-cache
    Pragma: no-cache

    服务器通过这三个头,告诉浏览器不要缓存资源;之所以会出现这么多头字段来告诉浏览器不要缓存数据,主要是市面上的浏览器不唯一 ;

    看代码

  • 相关阅读:
    Angular相关UI框架的安装
    Visual Studio Code 编辑器常用插件
    Groovy特性
    Notification(Android)消息推送机制
    Sublime SVN插件使用方法 PS:翻出来的旧笔记,现在Sublime和svn用的都不多了
    Python基本语法练习笔记(一)
    首篇博文占坑
    apache2修改用户和组
    如何修改script.bin/script.fex
    perl的INC设置
  • 原文地址:https://www.cnblogs.com/young-youth/p/11665733.html
Copyright © 2011-2022 走看看