zoukankan      html  css  js  c++  java
  • 《图解HTTP》读后记

     看了一遍又一遍…………不如记一下

    用做笔记的方式来看,发现了好多之前没发现的知识点。。。。。感觉前几次看了跟没看一样。。。

      1.1HTTP通常被译为超文本传输协议,但这种译法并不严谨。严谨的译名应该为“超文本转移协议”

        发送请求获取服务器资源的Web浏览器登,都可称为客户端。

      

      1.2 HTTP诞生于1989年3月

        HTTP/0.9

        HTTP于1990年问世,那时的HTTP并没有作为正式的标准被建立。现在的HTTP其实含有HTTP1.0之前版本的意思,因此被称为HTTP/0.9。

        HTTP/1.0

        HTTP正式作为标准被公布是在1996年的5月,版本被命名为HTTP/1.0,并记载于RFC1945。虽说是初期标准,但该协议标准至今仍被广泛使用在服务器端。

        HTTP/1.1

        目前主流

        HTTP/2.0

        HTTP/2.0(新一代加密协议)只应用于https://网址。

        Web浏览器诞生于1990年11月由CERN研发。

        1994年网景发布浏览器。1995年微软发布浏览器。HTML也发布了2.0版本。

        1995年微软公司与网景通信公司爆发浏览器战争,两家公司都对HTML做了扩展,导致写HTML页面时必须考虑兼容他们两家公司的浏览器,时至今日仍让前端工程师感到棘手。战争于2000年网景通信公司衰落而暂告一段落。2004年firefox问世,第二次浏览器大战随即爆发。

      1.3网络基础TCP/IP

        HTTP属于TCP/IP内部的一个子集。TCP/IP是互联网相关的各类协议族的总称。

     

        TCP/IP的分层管理,层次分别分为下面4层:应用层、传输层、网络层和数据链路层。

        应用层:面向客户的应用服务,如FTP、DNS、远程登录、邮件接收、HTTP也处于该层。

        传输层:有两种性质不同的协议:TCP、UDP。

            (TCP会有3次握手建立连接,优点可靠稳定,缺点慢、效率低、有确认、窗口、重传、拥塞控制机制,在数据传完后,还会断开连接用来节约系统资源。每个连接都占用系统的CPU、内存等硬件资源。因为TCP有确认机制、三次握手机制,这些也导致TCP容易被人利用,实现DOS、DDOS、CC等攻击。)

            (UDP优点快,没有TCP的控制机制,是一个无状态的传输协议,所以它在传递数据时非常快。攻击危险有UDP   Flood攻击……UDP的缺点: 不可靠,不稳定 因为UDP没有TCP那些可靠的机制,在数据传递时,如果网络质量不好,就会很容易丢包。 )

            (QQ信息用的UDP,qq视频、语音、使用的UDP,文件传输使用的TCP。直播软件(qq视频)如果视频卡了一下之后内容丢失则使用的UDP,(斗鱼等)卡了之后不会丢失部分视频的则是TCP)(qq的在线传输和离线传输分别用的UDP和TCP,猜的。)

        网络层:(形象的比喻为公路、路线。如需要经过哪个路由器,经过A电脑、B电脑后才能到达C电脑。确认路线)

        链路层:用来处理连接网络的硬件部分,包括硬件的设备驱动、控制操作系统、网卡、及光纤等。

        TCP/IP通信传输流

    发送端在层与层之间传输数据时,每经过一层时必定会被打上一个该层所属的首部信息。反之,接收端在层与层传输数据时,每经过一层时会把对应的首部消去。
    这种把数据信息包装起来的做法称为封装。

        1.4与HTTP关系密切的协议:IP、TCP和DNS

       哇!!一章章的写下去。。。没有那个毅力。。简洁
      IP和IP地址不相同,IP其实是一种协议的名称。IP协议的作用是把各种数据包传送给对方。而要保证确实传送到对方那里,则需要满足各类条件。其中两个重要的条件是IP地址和MAC地址。使用ARP协议凭借MAC地址进行通信。

      ARP是一种用以解析地址的协议,根据通信方的IP地址就可以反查出对应的MAC地址。

      没有人能够全面掌握互联网中的传输状况

       IP间的通信依赖MAC地址。在网络上,通信的双方在同一局域网(LAN)内的情况是很少的,通常是经过多台计算机和网络设备中转才能连接到对方。而在进行中转时,会利用下一站中转设备的MAC地址来搜索下一个中转目标。这时,会采用ARP协议。

      

        

        什么是DNS

       DNS服务是和HTTP协议一样位于应用层的协议。它提供域名到IP地址之间的解析服务。

       因为人类更容易识别名字(域名),而电脑更容易识别一长串数字字符(IP地址),所以DNS应运而生。(DNS运行原理还可探究)

        1.6各种协议与HTTP协议的关系

        1.7URI和URL

       URL:很熟悉的—网页地址

       URI:URI用字符串表示某一互联网资源,而URL表示资源的地址。形如地址后的/image/logo.gif。URL只是URI的一部分。(通俗点URL只定位了你的名称,名称可以试重复的,而URI定位到了你的身份证,身份证包含了名称)

     

      这里就说一下部分

      登录信息(认证)

      指定用户名和密码作为从服务器端获取资源时必要的登录信息(身份认证)。此项是可选项。

      服务器端口号

      指定服务器连接的网络端口号。此项也是可选项,若用户省略则自动使用默认端口号。

      带层次的文件路径

      index.htm就是服务器真实存在的一个文件的文件名

       查询字符串

      针对已指定的文件路径内的资源,可以使用查询字符串传入任意参数。此项可选。

      片段标识符

      使用片段标识符通常可标记出已获取资源中的子资源(文档内的某个位置)。但在RFC中并没有明确规定其使用方法。该项也为可选项。(就是定位吧。默认都是在顶部,直接跳转到页面的中间部位或者底部。演示地址:http://jmeter.apache.org/usermanual/component_reference.html#View_Results_Tree)

      2.简单的HTTP协议

      发送请求的为客户端。

      

      起始行开头的GET表示请求访问服务器的类型,称为方法(method)。随后的字符串/index.htm指明了请求访问的资源对象,也叫做请求URI(request-URI)。
      综合来看,这段请求内容的意思是:请求访问某台HTTP服务器上的/index.htm页面资源。
      请求报文是由请求方法、请求URI、协议版本、可选的请求首部字段和内容实体构成的。

    请求报文的构成

    接收到请求的服务器,会将请求内容的处理结果以响应的形式返回。

  • 相关阅读:
    Chapter 7 Integrity(完整性), Views(视图), Security(安全性), and Catalogs(目录)
    Qt计时器
    linux命令:linux文件处理命令
    JSON.stringify()的不常见用法
    flex知识点归纳
    css伪类
    开发资源汇总
    Math.cbrt() Math.sqrt() Math.pow()
    代码开发注意事项和规范
    关于数组数据容易忽略的点
  • 原文地址:https://www.cnblogs.com/zdfbk/p/8746254.html
Copyright © 2011-2022 走看看