xml地图|网站地图|网站标签 [设为首页] [加入收藏]
来自 新闻动态 2019-10-05 19:05 的文章
当前位置: 新濠国际登录平台 > 新闻动态 > 正文

客户端发送请求给服务器,基础的东西还是要不

1.   HTTP的请求方法以及响应状态码

接下来想系统的回顾一下TCP/IP协议族的相关东西,当然这些东西大部分是在大学的时候学过的,但是那句话,基础的东西还是要不时的回顾回顾的。接下来的几篇博客都是关于TCP/IP协议族的,本篇博客就先简单的聊一下TCP/IP协议族,然后聊一下HTTP协议,然后再聊一下SSL上的HTTP(也就是HTTPS)了。当然TCP/IP协议族是个老生常谈的话题,网络上关于该内容的文章一抓一大把呢,但是鉴于其重要性,还是有必要系统的总结一下的。

接下来想系统的回顾一下TCP/IP协议族的相关东西,当然这些东西大部分是在大学的时候学过的,但是那句话,基础的东西还是要不时的回顾回顾的。

HTTP状态码

HTTP状态码(HTTP Status Code)是用以表示网页服务器HTTP响应状态的3位数字代码。
HTTP状态码主要有5种,代表5种不同类型的响应:

  1. 1xx:信息性状态码,代表接收到请求,正在处理
  2. 2xx:成功状态码,代表请求正常处理完毕

    1. 200 OK
      表示从客户端发来的请求在服务端被正常处理了

    2. 204 No Content
      服务器接收的处理已经全部处理完毕,但是返回的响应报文中不含有实体的主体部分,另外也不允许返回任何的主体,浏览器接收到204响应之后页面不更新。

    3. 206 Partial Content
      客户端进行了范围请求,服务器成功执行了这部分的GET请求。响应报文中包含由Content-Range指定的实体内容。

  3. 3xx:重定向,表明浏览器需要执行某些特殊的处理以正确处理请求。

    1. 301 Moved Permanenty
      永久重定向,301表示请求的资源已经被分配了新的URI,以后应使用资源现在所指的URI。

    2. 302 Found
      临时重定向,该状态码表示请求的资源已被分配了新的URI,希望用户(本次)能够使用新的URI访问。
      与301不同,302是临时重定向,已移动的资源对应的URI在将来可能还是会发生改变。

    3. 303 See Other
      表示请求对应的资源存在着另一个URI,应使用GET方法定向获取请求的资源。

    4. 304 Not Modified
      304虽然被划分在3xx中,但是和重定向并没有关系。该状态码表示客户端发送附带条件的请求时,服务器允许请求访问资源,但因发生请求未满足条件的情况后,直接返回304 Not Modified(服务器资源未改变,可直接使用客户端未过期的缓存)。304状态码返回时,不包含任何响应的主体部分。

    5. 307 Temporary Redirect
      临时重定向。该状态码与302 Found 有着相同的含义。尽管302标准禁止POST变换成GET,但实际使用时大家并不遵守。
      307会遵照浏览器标准,不会从POST变成GET,但是对于处理响应的行为,每种浏览器有可能出现不同的情况。

  4. 4xx:客户端错误,表示服务器无法处理请求,错误是由于客户端引起的。

    1. 400 Bad Request
      请求报文中存在语法错误。当错误发生时,需修改请求的内容再次发送请求。

    2. 401 Unauthorized
      表示发送的请求需要有通过HTTP认证(BASIC认证、DIGEST认证)的认证信息。若之前已经进行过1次请求,则表示用户认证失败。
      返回含有401的响应必须包含一个使用于被请求资源的WWW-Authenticate首部用以质询(challenge)用户信息。当浏览器第一次接收401的时候,会弹出认证用的对话窗口。

    3. 403 Forbidden
      对请求资源的访问被服务器拒绝了。

    4. 404 Not Found
      服务器上无法找到请求的资源。

  5. 5xx:服务器错误,表示服务器在处理请求时出错

    1. 500 Internal Server Error
      服务器在执行请求时发生了错误,也有可能是web应用存在的bug或临时的故障。

    2. 503 Server Unaviabilable
      服务器暂时处于超负载或正在进行停机维护,现在无法处理请求。

1.1. 请求方法

http请求方法有GET、POST、PUT、HEAD、DELETE、OPTIONS、TRACE、CONNECT。当然上述方法是基于HTTP/1.1的,HTTP/1.0中独有的方法就不说了。

  • GET----获取资源
    • GET方法一般用来从服务器上获取资源的方法。服务器端接到GET请求后,就会明白客户端是要从服务器端获取相应的资源,然后就会根据请求报文中相应的参数,将需要的资源返回给客户端。使用GET方式的请求,传输的参数是拼接在URI上的。
  • POST----数据提交
    • POST方法一般用于表单提交,将客户端的数据塞到请求体中发送给服务器端。
  • PUT----上传文件
    • PUT方法主要用来上传文件,将文件内容塞到请求报文体中,传输给服务器。因为HTTP/1.1的PUT方法自身不带验证机制,所以任何人都可以上传文件,存在安全性,所以上传文件时不推荐使用。但是在设计接口使用REST标准时,可以使用PUT来做相应内容的更新。
  • HEAD----获取响应报文头
    • 响应端收到HEAD请求后,只会返回相应的响应头,不会返回响应体。
  • DELETE----删除文件
    • DELETE用于删除URI指定的资源,与PUT一样,自身也是不带验证机制的,不过在REST标准中可以用来做相应API的删除功能。
  • OPTIONS----查询支持的方法
    • OPTIONS方法是用来查询服务器可对那些请求方法做出响应,返回内容就是响应端所支持的方法。
  • TRACE----追踪路径
    • TRACE方法可追踪请求经过的代理路径,在发送请求时会为Max-Forwards头部字段填入数字,每经过一个代理中转Max-Forwards的值就会减一,直至Max-Forwards为零后,才会返回200。因为该方法易引起XST(Cross-Site Tracing,跨站追踪)攻击,所以不常用呢。
  • CONNECT----要求用隧道协议连接代理
    • CONNECT方法要求在与代理服务器通信时建立隧道,实现用隧道协议进行TCP通信。主要使用SSL(Secure Sockets Layer, 安全套接层)和TLS(Transport Layer Security, 传输安全层)协议将通信内容进行加密后经网络隧道传输。

 

一、TCP/IP协议组简述

在聊HTTPHTTPS之前呢,我们先简单的聊一下TCP/IP协议族。TCP/IP不单单指的就是TCPIP这两个协议,而是指的与其相关的各种协议。比如HTTP, FTP, DNS, TCP, UDP, IP, SNMP等等都属于TCP/IP协议族的范畴。

1、TCP/IP协议的分层

TCP/IP协议族是分层管理的,在OSI标准中可以分为7层(应用层、表示层、会话层、传输层、网络层、数据链路层、物理层,可记为:应表会传网数物),本篇博客我们采用的是TCP/IP协议族中的四层(应用层、传输层、网络层、链路层)。下方是对四层中每层的简单介绍:

  • 应用层:该层是面向用户的一层,也就是说用户可以直接操作该层,该层决定了向用户提供应用服务时的通信活动。本篇博客要聊的HTTPHyperText Transfer Protocol:超文本传输协议)就位于该层。我们经常使用的FTP(File Transfer Protocol: 文件传输协议)和DNS (Domain Name System:域名系统)都位于该层。FTP简单的说就是用来文件传输的。而DNS则负责域名解析的,通过DNS可以将域名(比如:www.cnblogs.com)与IP地址(201.33.xx.09)进行相互的转换。在7层中,又将该层分为:应用层、表示层和会话层。

  • 传输层:应用层的下方是传输层,应用层会将数据交付给传输层进行传输。TCP(Transmission Control Prococol:传输控制协议)和UDP(User Data Protocol: 用户数据协议)位于该层,当然见名知意,该层是用来提供处于网络连接中的两台计算机直接的数据传输的。TCP建立连接是需要三次握手来确认连接情况,而UDP则没有三次握手的过程。稍后会介绍。

  • 网络层:传输层的下方是网络层,网络层用来处理在网络上流动的数据包,IP(Internet Protocol:网际协议)就位于这层。该层负责在众多网络线路中选择一条传输线路。当然这个选择传输线路的过程需要IP地址和MAC地址的支持。

  • 链路层:在7层协议中,将链路层分为数据链路层和物理层。该部分主要是用来处理网络的硬件部分,我们常说的NIC(Net Work Card),也就是网卡就位于这一部分,当然光纤也是链路层的一部分。

新濠国际登录平台 1

TCP/IP协议族中的每次直接在传输数据时的协作关系,以及交互过程,还是引用《图解HTTP》一书上的一张图来解释吧。下图就是这四层协议在数据传输过程中的工作方式。下面这张图还是相当直观的。在发送端是应用层-->链路层这个方向的封包过程,每经过一层都会增加该层的头部。而接收端则是从链路层-->应用层解包的过程,每经过一层则会去掉相应的首部。

新濠国际登录平台 2

2、TCP协议的三次握手

在聊HTTP协议之前,我们先简单的聊一下TCP三次握手的过程,在后面的博客中我们将会对TCPIP协议进行详述,本篇博客就先简单的聊一下做HTTP协议的基础。

TCP协议位于传输层,为了确保传输的可靠性,TCP协议在建立连接时需要三次握手(Three-way handshaking)。下方这个简图就是TCP协议建立连接时三次握手的过程。

  • 第一次握手:发送端发送一个带SYN(Synchronize)标志的数据包给接收端,用于询问接收端是否可以接收。如果可以,就进行第二次握手。

  • 第二次握手:接收端回传给发送端一个带有SYN/ACK(Acknowledgement)的数据包,给发送端说,我收到你给我发送的SYN标志了,我再给你传一个ACK标志,你能收到吗?如果发送端收到了SYN/ACK这个数据包,就可以确认接收端收到了之前发送的SYN,

    然后进行第三次握手。

  • 第三次握手:发送端会给接收端发送一个带有ACK标志的数据包,告诉接收端我可以收到你给我发送的SYN/ACK标志。接收端如果收到了这个来自客户端的ACK标志,就意味着三次握手完成,连接建立,就可以开始传输数据了。

新濠国际登录平台 3

OSI七层模型

这篇文章讲的很详细了。

  1. 物理层 : 建立、维护、断开物理连接。
  2. 数据链路层 : 建立逻辑连接、进行硬件地址寻址、差错检验等功能。
  3. 网络层 : 进行逻辑地址寻址,实现不同网络之间的路径选择。
  4. 运输层 : 定义传输数据的协议端口号,以及流控和差错校验。
    协议有:TCP UDP ,数据包一旦离开网卡即进入网络传输层。
  5. 会话层 : 建立、管理、终止会话。
  6. 表示层 : 数据的表示、安全和压缩。
  7. 应用层 : 网络服务与最终用户的一个接口。
    协议有:HTTP FTP TFTP SMTP POP3 SNMP DNS TENNET HTTPS DHCP

1.2. 响应状态码

HTTP协议的响应状态码。顾名思义,响应状态码是用来标志HTTP响应状态的,响应状态由响应状态码和响应原因短语构成,当然状态码有很多中,本部分就挑出来常用的状态码进行讨论。下方是响应状态码可以分为的几大类:

  • 1xx ---- Informational(信息性状态码),表示接受的请求正在处理。
  • 2xx ---- Success (成功),表示请求正常处理完毕。
  • 3xx ---- Redirection (重定向),表示要对请求进行重定向操作,当然其中的304除外。
  • 4xx ---- Client Error (客户端错误),服务器无法处理请求。
  • 5xx ---- Server Error (服务器错误),服务器处理请求时出错。

上面是响应状态码的整体分类,接下来介绍一些常用的响应状态码。

  (01)、200 OK : 表示服务端正确处理了客户端发送过来的请求。

  (02)、204 No Content ['kɒntent]内容: 表示服务端正确处理请求,但没有报文实体要返回。

  (03)、206 Partial [ˈpɑ:ʃl]部分 Content :表示服务端正确处理了客户端的范围请求,并按照请求范围返回该指定范围内的实体内容。

  (04)、301 Moved Permanently['pɜ:mənəntlɪ]永久的:永久性重定向,若之前的URI保存到了书签,则更新书签中的URI。

  (05)、302 Found:临时重定向,该重定向不会变更书签中的内容。

  (06)、303 See Other:临时重定向,与302功能相同,但是303状态吗明确表示客户端应当采用GET方法获取资源。

  (07)、304 Not Modified: 资源未变更,该状态码与重定向并没有什么关系,当返回该状态码时,告诉客户端请求的资源并没有更新,响应报文体中并不会返回所请求的内容。

  (08)、400 Bad Request: 错误请求,表示请求报文中包含语法错误。

  (09)、401 Unauthorized[ʌnˈɔ:θəraɪzd]未经许可的:请求未认证,表示此发送的请求需要客户端进行HTTP认证(稍后会提到)。

  (10)、404 Not Found:找不到相应的资源,表示服务器找不到客户端请求的资源。

  (11)、500 Internal [ɪnˈtɜ:nl]Server Error:服务器内部错误,表示服务器在处理请求时出现了错误,发生了异常。

  (12)、503 Service Unavailable[ˌʌnəˈveɪləbl]难以获得的:服务不可用,表示服务器处于停机状态,无法处理客户端发来的请求。

 

一、TCP/IP协议组简述

二、HTTP报文结构

HTTP协议全称是HyperText Transfer Protocol,即超文本传输协议,用户客户端和服务器之前的通信,目前普遍使用版本为HTTP/1.1。协议本质上就是规范,我们之前提到过的“面向接口”编程,其实就是“面向协议”编程。先定义好类的协议,也就是接口,相关类都遵循该协议,这样一来我们就规范了这些类的调用方式。而HTTP协议是规范客户端和服务器之间通信的协议。也就是说所有的客户端或者服务器都遵循了HTTP这个通信协议,那么也就是意味着他们对外传输数据的接口是一直的,就可以在其中间连接上管道,这样一来就可以进行传输了。

这些协议就是接口,有着共同的通信协议,多个端就可以相互通信。采用相同的协议,就是便于个个设备之间进行沟通交流。HTTP协议的作用如下所示。

新濠国际登录平台 4

HTTP协议的作用是用来规范通信内容的,在HTTP协议中可以分为请求报文和响应报文。顾名思义,请求报文是请求方发出的信息,而响应报文是响应端收到请求后响应的内容。接下来我们就来看看请求报文和响应报文的整体结构。

1、请求报文(Request Message)结构

下方是请求报文的整体结构。请求报文主要分为两大部分,一个是请求头Request Headers另一个是请求体Request Body。这两者之间由空行分割。在请求头中又分为请求行Request Line,请求头部字段,通用头部字段和实体头部字段等,这个稍后会详细介绍。下方就是请求报文的结构。

新濠国际登录平台 5

下方这个截图就是请求博客园某个页面时的Request Headers。在请求行中的第一个“GET”是当前请求的方法,稍后会做介绍。中间的就是请求资源的路径,最后一个HTTP/1.1就是当前使用请求协议及其版本。下方这些就是请求头了,稍后会对常用的请求头进行解说。而请求体就是你往服务端传输的数据,比如form表单神马的。

新濠国际登录平台 6

2、响应报文(Response Message)结构

聊完请求报文,接下来我们来聊聊响应报文,响应报文的结构与请求报文的结构类似,也分为报文头和报文体。下方就是响应报文的结构图。响应头(Response Headers)分为状态行(State Line),响应头部字段,通用头部字段、实体头部字段等。响应头与响应体中间也是有空行进行分割的。

新濠国际登录平台 7

下方截图就是上述请求报文发出后的响应头,响应体就是对于的HTML等前端资源了。在响应头中,第一行就是状态行,“HTTP/1.1”表示使用的HTTP协议的1.1版本,状态200表示响应成功,"OK"则是状态原因短语。常用状态,稍后会详细介绍。

新濠国际登录平台 8

HTTP协议的工作特点与工作原理

在聊HTTP与HTTPS之前呢,我们先简单的聊一下TCP/IP协议族。TCP/IP不单单指的就是TCP和IP这两个协议,而是指的与其相关的各种协议。比如HTTP, FTP, DNS, TCP, UDP, IP, SNMP等等都属于TCP/IP协议族的范畴。

三、HTTP的请求方法以及响应状态码

上面在介绍请求报文中提到的“GET”就是请求请求方法,而在响应报文中提到的“200”状态码,就是稍后要聊的响应状态码。请求方法和响应状态码在HTTP协议中算是比较重要的内容了。之前我们在使用Perfect框架开发服务器端的时候,曾聊过请求方法中的GET、POST、PUT以及DELETE,并且这四种方法可以结合着REST使用。本部分是以HTTP协议的角度来聊的请求方法,所以与之前会有稍稍的不同。本部分我们就来聊一下HTTP协议的请求方法和响应状态码。

1、请求方法

接下来我们要聊的请求方法有GET、POST、PUT、HEAD、DELETE、OPTIONS、TRACE、CONNECT。当然上述方法是基于HTTP/1.1的,HTTP/1.0中独有的方法就不说了。

GET----获取资源

  • GET方法一般用来从服务器上获取资源的方法。服务器端接到GET请求后,就会明白客户端是要从服务器端获取相应的资源,然后就会根据请求报文中相应的参数,将需要的资源返回给客户端。使用GET方式的请求,传输的参数是拼接在URI上的。

POST----数据提交

  • POST方法一般用于表单提交,将客户端的数据塞到请求体中发送给服务器端。

PUT----上传文件

  • PUT方法主要用来上传文件,将文件内容塞到请求报文体中,传输给服务器。因为HTTP/1.1的PUT方法自身不带验证机制,所以任何人都可以上传文件,存在安全性,所以上传文件时不推荐使用。但是之前我们在设计接口使用REST标准时,可以使用PUT来做相应内容的更新。

HEAD----获取响应报文头

  • 响应端收到HEAD请求后,只会返回相应的响应头,不会返回响应体。

DELETE----删除文件

  • DELETE用于删除URI指定的资源,与PUT一样,自身也是不带验证机制的,不过在REST标准中可以用来做相应API的删除功能。

OPTIONS----查询支持的方法

  • OPTIONS方法是用来查询服务器可对那些请求方法做出相应,返回内容就是响应端所支持的方法。

TRACE----追踪路径

  • TRACE方法可追踪请求经过的代理路径,在发送请求时会为Max-Forwards头部字段填入数字,每经过一个代理中转Max-Forwards的值就会减一,直至Max-Forwards为零后,才会返回200。因为该方法易引起XST(Cross-Site Tracing,跨站追踪)攻击,所以不常用呢。

CONNECT----要求用隧道协议连接代理

  • CONNECT方法要求在与代理服务器通信时建立隧道,实现用隧道协议进行TCP通信。主要使用SSL(Secure Sockets Layer, 安全套接层)和TLS(Transport Layer Security, 传输安全层)协议将通信内容进行加密后经网络隧道传输。

2、响应状态码

聊完请求方法后,接下来我们来聊聊HTTP协议的响应状态码。顾名思义,响应状态码是用来标志HTTP响应状态的,响应状态由响应状态码和响应原因短语构成,当然状态码有很多中,本部分就挑出来常用的状态码进行讨论。下方是响应状态码可以分为的几大类:

  • 1xx ---- Informational,表示接受的请求正在处理。
  • 2xx ---- Success ,表示请求正常处理完毕。
  • 3xx ---- Redirection ,表示要对请求进行重定向操作,当然其中的304除外。
  • 4xx ---- Client Error ,服务器无法处理请求。
  • 5xx ---- Server Error ,服务器处理请求时出错。

上面是响应状态码的整体分类,接下来介绍一些常用的响应状态码。

200 OK : 表示服务端正确处理了客户端发送过来的请求。

204 No Content : 表示服务端正确处理请求,但没有报文实体要返回。

206 Partial Content :表示服务端正确处理了客户端的范围请求,并按照请求范围返回该指定范围内的实体内容。

301 Moved Permanently:永久性重定向,若之前的URI保存到了书签,则更新书签中的URI。

302 Found:临时重定向,该重定向不会变更书签中的内容。

303 See Other:临时重定向,与302功能相同,但是303状态吗明确表示客户端应当采用GET方法获取资源。

304 Not Modified: 资源未变更,该状态码与重定向并没有什么关系,当返回该状态码时,告诉客户端请求的资源并没有更新,响应报文体中并不会返回所请求的内容。

400 Bad Request: 错误请求,表示请求报文中包含语法错误。

401 Unauthorized:请求未认证,表示此发送的请求需要客户端进行HTTP认证。

404 Not Found:找不到相应的资源,表示服务器找不到客户端请求的资源。

500 Internal Server Error:服务器内部错误,表示服务器在处理请求时出现了错误,发生了异常。

503 Service Unavailable:服务不可用,表示服务器处于停机状态,无法处理客户端发来的请求。

出处:

工作特点

  • 基于B/S模式
  • 通信开销小、传输快速、传输成本低
  • 使用灵活、可使用超文本传输协议
  • 节省传输时间
  • 无状态

1.TCP/IP协议的分层

工作原理

客户端发送请求给服务器,创建一个TCP连接,指定端口号(默认为80),服务器监听浏览器请求,一旦监听到客户端请求,分析请求类型后,服务器会向客户端返回状态信息和数据内容。

TCP/IP协议族是分层管理的,在OSI标准中可以分为7层(应用层、表示层、会话层、传输层、网络层、数据链路层、物理层,可记为:应表会传网数物),本篇博客我们采用的是TCP/IP协议族中的四层(应用层、传输层、网络层、链路层)。下方是对四层中每层的简单介绍:

HTTP协议常见的请求/相应头

  • Content-Type :实体主体内对象的媒体类型,和Accept一样,字段值用type/subtype形式赋值。

    Content-Type: text/html; charset=UTF-8

  • Accept :可通知服务器用户代理能够处理的媒体类型及媒体类型的相对优先级。可使用 type/subtype 这种形式,一次指定多种媒体类型。

    Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8

    • 文本类型
      text/html, text/plain, text/css ...
      application/xhtml+xml, application/xml ...

    • 图片类型
      image/jpeg, image/gif,image/png ...

    • 视频文件
      video/mpeg, video/quicktime ...

    • 应用程序使用的二进制文件
      application/octet-stream, application/zip ...

  • Origin :最初的请求来源与哪,主要用与post请求

  • Cookie :HTTP请求发起时,发送给服务端的cookie值
  • Cache-Control :指定请求和响应的缓存机制
  • User-Agent :用户信息
  • Referrer :上级请求路径
  • X-Forwarded-For :强求端的真实IP(做代理的时候可以用次来获取)
  • Access-Control-Allow-Origin :允许特定的域名来进行访问,通常用做跨域使用
  • 新濠国际登录平台,Last-Modified :指明资源最终修改的时间
  • style="color: #ff0000">应用层:该层是面向用户的一层,也就是说用户可以直接操作该层,该层决定了向用户提供应用服务时的通信活动。本篇博客要聊的HTTP(HyperText

    Transfer Protocol:超文本传输协议)就位于该层。我们经常使用的 style="color: #ff0000">FTP(File Transfer Protocol: 文件传输协议)和DNS (Domain Name System: 域名系统)都位于该层。FTP简单的说就是用来文件传输的。而DNS则负责域名解析的, style="color: #ff0000">通过DNS可以将域名(比如:www.cnblogs.com)与IP地址(201.33.xx.09)进行相互的转换。 style="color: #ff0000">在7层中,又将该层分为:应用层、表示层和会话层。

  • style="color: #ff0000">传输层:应用层的下方是传输层,应用层胡将数据交付给传输层进行传输。 style="color: #ff0000">TCP(Transmission Control

    Prococol:传输控制协议)和 style="color: #ff0000">UDP(User Data Protocol: 用户数据协议)位于该层,当然见名知意,该层是用来提供处于网络连接中的两台计算机直接的数据传输的。 style="color: #ff0000">TCP建立连接是需要三次握手来确认连接情况,而UDP则没有三次握手的过程。稍后会介绍。

  • style="color: #ff0000">网络层:传输层的下方是网络层,网络层用来处理在网络上流动的数据包, style="color: #ff0000">IP(Internet Protocol:

    网际协议)就位于这层。该层负责在众多网络线路中选择一条传输线路。当然这个选择传输线路的过程需要IP地址和MAC地址的支持。

  • 链路层:在7层协议中,将 style="color: #ff0000">链路层分为数据链路层和物理层。该部分主要是用来处理网络的硬件部分,我们常说的NIC(Net

    Work Card),也就是网卡就位于这一部分,当然光纤也是链路层的一部分。

HTTP协议的请求方法

  • GET
  • POST
  • HEAD
  • OPTIONS
  • PUT
  • DELETE
  • TRACE

GET 和 POST 的区别:

  1. GET在刷新和后退时,没影响,而POST会重新提交信息。
  2. GET可以被收藏为书签,而POST不行。
  3. GET 可以被缓存,POST不行。
  4. GET 请求时,编码类型为 application/x-www-form-urlencoded,POST 除了这个,还可以是Multipart/form-data(文件上传)
  5. GET 参数直接显示在url中,post看不到
  6. 由于url限制,GET 的数据量是有限的
  7. POST比GET更安全

  新濠国际登录平台 9

HTTPS 的工作原理

HTTPS 是一种基于SSL/TLS的HTTP协议,所有的HTTP数据都是在SSL/TLS协议封装之上传输的。

HTTPS 协议在HTTP 协议的基础上,添加了SSL/TLS握手以及数据加密传输,也属于应用层协议。

在TCP/IP协议族中的每次直接在传输数据时的协作关系,以及交互过程,还是引用《图解HTTP》一书上的一张图来解释吧。下图就是这四层协议在数据传输过程中的工作方式。下面这张图还是相当直观的。在发送端是应用层-->链路层这个方向的封包过程,没经过一层都会增加该层的头部。而接收端则是从链路层-->应用层解包的过程,每经过一层则会去掉相应的首部。

常见网络协议含义及端口

  • FTP :文件传输协议(21)
  • Telnet :用于远程登录的端口(23)
  • SMTP :定义了简单邮件传输协议(25)
  • POP3 :接收邮件(110)
  • HTTP :超文本传输协议(80)
  • DNS :域名解析服务(53)

  新濠国际登录平台 10

 

2、TCP协议的三次握手

在聊HTTP协议之前,我们先简单的聊一下TCP三次握手的过程,在后面的博客中我们将会对TCP和IP协议进行详述,本篇博客就先简单的聊一下做HTTP协议的基础。

TCP协议位于传输层,为了确保传输的可靠性,TCP协议在建立连接时需要三次握手(Three-way handshaking)。下方这个简图就是TCP协议建立连接时三次握手的过程。

  • style="color: #ff0000">第一次握手:发送端发送一个带 style="color: #ff0000">SYN(Synchronize)标志的数据包给接收端,用于询问接收端是否可以接收。如果可以,就进行第二次握手。

  • style="color: #ff0000">第二次握手:接收端回传给发送端一个带有 style="color: #ff0000">SYN/ACK(Acknowledgement)的数据包,给发送端说,我收到你给我发送的SYN标志了,我再给你传一个ACK标志,你能收到吗?如果发送端收到了 style="color: #ff0000">SYN/ACK这个数据包,就可以确认接收端收到了之前发送的SYN,

    然后进行第三次握手。

  • style="color: #ff0000">第三次握手:发送端会给接收端发送一个带有 style="color: #ff0000">ACK标志的数据包,告诉接收端我可以收到你给我发送的 style="color: #ff0000">SYN/ACK标志。接收端如果收到了这个来自客户端的ACK标志,就意味着三次握手完成,连接建立,就可以开始传输数据了。

  新濠国际登录平台 11

本文由新濠国际登录平台发布于新闻动态,转载请注明出处:客户端发送请求给服务器,基础的东西还是要不

关键词: