(一)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]
若干个请求头
Accepttext/html,application/xhtml+xm…plication/xml;q=0.9,/;q=0.8
Accept-Languagezh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3
Accept-Encodinggzip, deflate
Connectionkeep-alive
Upgrade-Insecure-Requests1
…………
一个空行( 这里有一个空行,在请求数据与请求内容之间)
实体内容(只有用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

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

看代码

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值