zoukankan      html  css  js  c++  java
  • http协议类

    详情;https://www.cnblogs.com/fsg6/p/13082013.html

    • 网络基础
      • TCP/IP的分层管理
      • 基于浏览器的连接处理(在浏览器上输入URL到页面渲染的过程)
    • HTTP协议的主要特点
    • HTTP报文的组成部分
    • HTTP方法
    • GET和POST请求的区别
    • 常见状态码
    • 什么是持久连接(了解)
    • 什么是管线化(了解)

    ok!接下来让我们来一一攻破

    网络基础

    • TCP/IP的分层管理
      • TCP/IP最重要的一个特点就是分层管理,分别为:
        • 应用层 --- 决定向用户提供应用服务时的通信活动,http、ftp、dns 都属于这一层
        • 安全层(TSL/SSL) --- 如果是https的请求会存在这一层,http的请求则无此层,注意!!!!!!
        • 传输层 --- 传输层对上层应用层提供处于网络连接中两台计算机之间的数据传输
        • 网络层 --- 网络层用来处理网络上流动的数据包,数据包是网络传输的最小数据单位
        • 链路层 --- 用来处理连接网络的硬件部分,包括控制操作系统、硬件的设备驱动等物理可见部分
    • 一问:基于浏览器的连接处理(浏览器从输入url到页面渲染出来的过程)(-- HTTP权威指南)
      • 浏览器从url中解析出服务器的主机名
      • 浏览器将服务器的主机名转换成服务器的IP地址(DNS)
      • 浏览器将端口号从url中解析出来
      • 浏览器建立一条与web服务器的TCP连接
      • 浏览器向服务器发送一条HTTP的请求报文
      • 服务器向浏览器回送一条HTTP的响应报文
      • 关闭连接,浏览器渲染
    • 二问:浏览器建立一条与web服务器的TCP连接的时候多了哪些事(三次握手/四次挥手)?或者会追问浏览器的渲染过程是什么样?又或者是TCP的作用是啥
      • 三次握手
        • 客户端首先发送一个带有SYN标志的数据包给服务端
        • 服务端接受SYN数据包之后,回传一个SYN/ACK标志的数据包以示传达确认连接信息
        • 客户端收到SYN/ACK的确认数据包之后,再回传一个ACK标志的数据包给服务端,表示‘握手’结束
      • 四次挥手
        • 客户端向服务端先发送一个带有FIN标志的数据包给服务端
        • 服务端接受FIN数据包之后,回传一个ACK的数据包给客户端以示传达确认关闭信息
        • 服务端向客户端发送一个FIN标志的数据包,请求关闭连接
        • 客户端收到FIN的数据包之后,回传一个ACK的数据包给服务端,以表示确认关闭
      • TCP的作用是啥(个人觉得没几个变态公司会问,可以当作了解)
        • 提供无差错的数据传输
        • 按序传输(数据总是会按照发送顺序到达)
        • 未分段的数据流(可以在任意时刻以任意尺寸将数据发送出去)
      • 浏览器的渲染过程
        • html元素转成DOM tree
        • css 样式转成CSS tree
        • DOM tree和CSS tree整合形成Render tree
        • 通过layout计算DOM 元素要显示的位置和样式
        • 浏览器进行绘制渲染

    HTTP协议的主要特点

    • 简单快速 --- 可以理解为每个资源的URI(统一资源定位符)都是固定的,所以在http协议处理起来比较容易
    • 灵活 --- 每个http协议的头部都有一个类型,通过一个http协议就能完成不同类型的传输,所以比较灵活
    • 无连接(重)--- http协议连接一次之后就会断开,不会保持连接
    • 无状态(重)--- 可以理解为服务端和客户端是两种身份,单从http协议中是无法区分两次协议者的身份

    HTTP报文的组成部分

    • 请求报文:
      • 请求行 --- 包含http方法,页面地址,http协议,http版本
      • 请求头 --- 包含一些key:value的值,eg: host、Cache-Control,Accept,Cookie等
      • 空行 --- 用来告诉服务端往下就是请求体的部分啦
      • 请求体 --- 就是正常的query/body参数
    • 响应报文:
      • 状态行 --- 包含http方法,http协议,http版本,状态码
      • 响应头 --- 包含一些key:value的值,eg: Content-type,Set-cookie, Cache-Control, Date, Server等
      • 空行 --- 用来告诉客户端往下就是响应体的部分啦
      • 响应体 --- 就是服务端返回的数据

    HTTP方法

    • GET -- 获取资源
    • POST -- 传输资源
    • PUT -- 更新资源,常用来做传输文件
    • DELETE -- 删除资源
    • HEAD -- 获取请求报文首部
    • OPTIONS -- 询问支持的方法,查询针对请求URI指定的资源支持的方法

    GET和POST请求的区别

    • GET产生的URL地址可以被收藏,而POST不可以
    • GET请求会被浏览器主动缓存,而POST不会,除非自动设置
    • GET请求参数会被完整的保留在浏览器历史里,而POST的参数不会被保留
    • GET请求在URL中传输参数有长度限制,而POST没有
    • POST比GET更安全,因为GET请求的参数直接暴露在URL上
    • GET参数通过URL传输,而POST参数放在request body中


    常见状态码

    • 1XX --- 指示信息,表示请求已接受,继续处理
    • 2XX --- 成功,表示请求已被成功接受
      • 200 --- OK,客户端请求成功
      • 206 --- 客户端发送了一个带有Range头的GET请求,视频/音频可能会用到
    • 3XX --- 重定向,要完成请求,必需进行近一步操作
      • 301 --- 重定向,所请求的界面转移到新的url,永久重定向
      • 302 --- 同上301,但是是临时重定向
      • 304 --- 缓存,服务端告诉客户端有缓存可用,不用重新请求
    • 4XX --- 客户端错误,请求有语法错误或请求无法实现
      • 400 --- Bad Request, 客户端请求有语法错误
      • 401 --- Unauthorized, 请求未授权
      • 403 --- Forbidden, 禁止页面访问
      • 404 --- Not found, 请求资源不存在
    • 5XX --- 服务端错误,服务器未能实现合法的请求
      • 500 --- Internal Server Error, 服务器错误
      • 503 --- Server Unavailable, 请求未完成,服务器临时过载或者宕机,一段时间后可恢复正常

    什么是持久连接

    • 当使用Keep-alive模式(又称持久连接,连接重用 http1.1的版本才支持)时,Keep-alive 功能使客户端到服务端的连接持续有效,当出现服务器的后续请求时,Keep-alive 避免了建立或者重新建立连接

    什么是管线化

      • 在使用持久连接的情况下,某个连接上的消息传递类似于:
        • 请求1 --> 响应1 --> 请求2 --> 响应2 --> 请求3 --> 响应3
      • 管线化的连接消息传递是类似于:
        • 请求1 --> 请求2 --> 请求3 --> 响应1 --> 响应2 --> 响应3
        • 相当于客户端一次性把所有的请求打包发送给服务端,同时服务端也一次性打包将所有的返回回传回来
        • 只有GET和HEAD请求可以进行管线化,而POST有所限制
        • 管线化是通过持久连接完成的,且只有http / 1.1 版本支持
  • 相关阅读:
    解决Xcode8打印了nw_socket_handle_socket_event Event mask
    调用系统框架使用设备系统语言的设置,相册相机设置为中文
    ios开发 之 设置多种文字颜色/背景色/文字下划线/行间距 NSString
    IOS 开发中 Whose view is not in the window hierarchy 错误的解决办法
    UITableView设置cell的separator 分割线
    iOS用户点击推送消息进入应用后自动跳转到对应的ViewController
    随感
    JS获取当前网页大小以及屏幕分辨率等
    js将秒转换为 分:秒 函数
    css实现强制不换行/自动换行/强制换行
  • 原文地址:https://www.cnblogs.com/fsg6/p/14538285.html
Copyright © 2011-2022 走看看