zoukankan      html  css  js  c++  java
  • HTTP协议学习笔记

    第一章 WEB网络基础

    1.1 TCP/IP协议族

    应用层、传输层、网络层、数据链路层

    1. 应用层:向用户提供应用服务时的通信活动,FTP、HTTP协议就在该层

    2. 传输层:网络连接中的两台计算机提供数据传输、该层主要协议有TCP、UDP

    3. 网络层:用来处理网络传输中的数据包,数据包是网络传输中的最小数据单位

    4. 数据链路层:处理网络连接中的硬件设备,包括操作系统、网络适配器、光纤等等

    图解HTTP

    图出自《图解HTTP》一书

    这里写图片描述
    图出自《图解HTTP》一书

    1.2 IP协议

    IP协议是一种网络层的协议,用来处理数据包的传送。包括了两个重要的地址,IP地址和、MAC地址。
    IP地址指明了节点被分配的地址,MAC地址则指明了网卡(网络适配器)固定的地址。IP地址可以变换,MAC地址就基本不变

    1.3 DNS协议

    DNS(Domain Name System)是位于应用层的协议,负责域名解析服务,DNS通过域名查找IP地址,或逆向从IP地址反向查找域名

    第二章 HTTP协议简介

    2.1 HTTP协议

    HTTP协议是一种无状态协议,也即不保存请求和响应的状态。HTTP协议这样设计是为了提高响应效率。但是随着互联网的发展,一些特定场景就需要有状态的。所以HTTP也加进来了Cookie技术。

    2.2 URI和URL

    URI(Uniform Resource Identifier),也即统一资源标记协议。URL(Uniform Resource Location),也即统一资源地址。可见URL是URI的子集。

    2.3 HTTP报文

    用于HTTP协议交互的信息被称作HTTP报文。请求端(客户端)的报文被称作请求报文,响应端(服务器端)的报文被称作响应报文。HTTP报文包括报文首部和报文主体。

    请求报文构成
    这里写图片描述

    响应报文构成
    这里写图片描述

    这里写图片描述

    这里写图片描述

    2.4 HTTP方法

    GET:获取资源

    POST:传输实体主体

    PUT:传输文件
    PUT方法不带验证机制,所以不安全

    OPTIONS:请求URI指定资源支持的方法

    HEAD:获取报文首部

    DELETE:删除文件
    HTTP/1.0的DELETE和PUT方法一样不带验证机制,所以文件上传和删除都不安全

    TRACE:将服务器之前的请求通信环回给客户端

    CONNECT:要求用隧道协议连接代理,主要用隧道协议进行TCP通信。主要使用SSL(Secure Sockets Layer)和TLS(Transport Layer Security)协议将通信内容加密后经网络隧道传输

    2.5 HTTP状态码

    (1). 1xx 正在处理

    (2). 2xx 成功

    200(OK):表示请求成功
    
    204(No Content):表示请求成功,但是没有资源返回
    
    206(Partial Content):表示客户端进行范围请求,服务端执行GET方法进行响应
    

    (3). 3xx 重定向

    301(Moved Permanently):永久性重定向。表示请求的URI已经被指定了新的URI,用户以后要用新的URI访问。<br>
    
    302(Found):临时性重定向。表示请求的URI已经被指定了新的URI,用户(本次)要使用新的URI访问。与301的不同就是URI改变是临时的,以后可以重新变回来 <br>
    
    303(See Other):303和302功能一样,不过303要求以GET方法获取资源 <br>
    
    304(Not Modified):表示客户端发送附带条件的请求,但是未符合条件。
    
    307(Temporary Redirect):临时重定向。和302的区别就是遵照浏览器的标准,不会从POST变成GET。
    

    (4). 4xx 客户端错误

    400(Bad Request):表示请求报文中存在语法错误。
    
    401(Unauthorized):表示请求需要有通过HTTP认证(BASIC认证,DIGEST认证)
    
    403(Forbidden):表示请求访问被服务器拒绝了。因权限问题被服务器拒绝的访问都可以是403。
    
    404(Not Found):表示服务器没有找到请求资源
    

    (5). 5xx 服务器错误

    500(Internal Server Error):服务端在执行请求时发生错误
    
    503(Service Unavailable):表示服务器超负载或者在这进行停机维护。
    

    第三章 通信数据转发程序

    HTTP协议进行通信时,不仅需要客户端和服务端,还需要一些进行转发的程序,比如代理、网关、隧道

    3.1 代理

    代理是一种具有转发功能的程序,接收客户端的请求,并转发给服务端。

    使用代理服务器的目的是利用缓存技术,减少网络带宽流量的使用,代理实现是先将副本放在代理服务器上,客户端访问的话,先从代理服务器获取资源,没有的话,再从源服务器获取资源。使用缓存的代理称作缓存代理。

    如果代理服务器不对报文进行处理的,称作透明代理,反之成为非透明代理。

    代理是不会改变URI的,通过代理服务器转发请求或者响应协议时,会在报文首部追加写上Via信息,如图所示,图来自《图解HTTP图书》一书
    代理

    3.2 网关

    网关是转发其它服务器通信数据的程序。接收从客户端发生的数据,并进行处理

    网关可以将HTTP协议转换为其它协议,然后再转发给非HTTP服务器。网关可以提供通信的安全性,网关可以在通信线路加密以确保安全性

    3.3 隧道

    隧道是远程客户端和服务端两者之间进行中转,并保持双方通信连接的应用程序。隧道使用SSL等加密手段进行加密处理,保证远程客户端和服务端之间通信的安全性。

  • 相关阅读:
    CSS 中z-index全解析(摘自阿里西西)
    Video标签的使用
    HTML标签解释大全
    在html中插入音频
    ABAP更改现有程序
    乱糟糟的笔记
    ABAP提示信息对话框
    【学习】几种查找增强的方法
    【学习】ABAP OLE 对EXCEL的处理
    【转载】ABAP-如何读取内表的字段名称
  • 原文地址:https://www.cnblogs.com/mzq123/p/9064715.html
Copyright © 2011-2022 走看看