美文网首页
Http 基础

Http 基础

作者: 老奶瓶 | 来源:发表于2020-07-20 01:45 被阅读0次

[toc]

Http 基础

Http的原理和工作机制

Http 定义 Http到底是什么

直观印象:

  1. 浏览器输入地址,打开网页
  2. Android发送请求,返回对应的内容

HyperText Transfer Protocol 超文本传输协议

  • 超文本:在电脑显示的,含有可以指向其他文本的文本

    其实就是Html,http最初就是为了传输Html文档而诞生的。

    HyperText ,所谓的超其实是可扩展的意思。

HTTP 的工作方式

浏览器 :

用户输入地址后回⻋或点击链接 -> 浏览器拼装 HTTP 报文并发送请求给服务器 -> 服 务器处理请求后发送响应报文给浏览器 -> 浏览器解析响应报文并使用渲染引擎显示 到界面

手机 App :

用户点击或界面自动触发联网需求 -> Android 代码调用拼装 HTTP 报文并发送请求 到服务器 -> 服务器处理请求后发送响应报文给手机 -> Android 代码处理响应报文并 作出相应处理(如储存数据、加工数据、显示数据到界面)

URL -> HTTP报文

URL 格式

三部分:协议类型、服务器地址(和端口号)、路径(Path) 协议类型://服务器地址[:端口号]/路径

http://hencoder.com/users?gender=male

在浏览器输入Url会被转化成请求报文。

请求报文 Request

image-20200720013214148.png

Host不是给服务器看的,是给主机的,所以不属于请求行。

Http 有,0.9 1.1 2.0版本,0.9已经废弃,1.1正被大量使用,正在向2.0迁移

Body,提供给服务器看的具体内容(一般般业务相关),不是必须的。

Body是提供给服务器,让服务器去处理的内容,而用来定位请求的都在Head中。

响应报文

image-20200720013926845.png

和请求报文(Request)基本一样,

除了第一行,叫状态行。返回了一个状态码和状态信息,是这次请求的简单描述。

Http的请求方法和状态码

请求方法

重复执行多次结果还是一样,就是有幂等性

Get

  • 获取资源,没有Body,具有幂等性
  • 是第一个版本(0.9)就存在的方法,在浏览器输入地址调用的就是Get方法,它不对服务器的数据进行操作。

Body是操作服务器数据用的,里面的的内容是给服务器读的,作为只获取数据不操作数据的Get请求自然不需要Body

如果想传递参数,就要拼在Requst 请求行等path上 比如 /user/1 传递参数1

Get /users/1 Http/1.1
Host api.github.com

在Get 增加Body标签,Retrofit甚至会报错。

Post

  • 增加和修改资源,有且一定有Body,不具有幂等性

既然要新增/修改资源,不增加参数(Body)服务器自然无法修改

Put

  • 修改(只修改),有Body,具有幂等性

既然Post的和Put的区别

相似 区别
都可以修改数据都符合标准 Post不具有幂等性,执行多次返回不同的结果,因为它可以增加资源。Put具有幂等性,执行多次返回相同的结果,例如多次修改性别为女,结果用户的性别还是女。

Delete

  • 删除资源,没有Body,有幂等性(删除用户1,重复执行无反应,因为已经删除了,从结果来看是一样的)
Delete /users/1 Http/1.1
Host api.github.com  

从path就足以定位用户删除了,无需Body

Head

和Get请求完全相同,返回响应没有Body,其他请求方法的响应都是有Body的。可以快速得到资源信息。

状态码 (日常中最重要的2打头 成功,4打头客户端错误。)

  • 作用: 对结果作出类型化的描述(如获得成功,内容未找到)

  • 1xx:临时性消息。如:

    • 100 (继续发送),如果你发送的文件太大,想分段发送。

      Header传Excpet: 100-continue

      服务器响应HTTP/1.1 100代表允许你继续发送。

      发送成功后返回HTTP/1.1 200或者201

    • 101(正在切换协议 比如http1.1和http2.0的请求不兼容,

    • 一般会加一个Upgrade: h2c的header试着请求,询问服务器是否支持Http2.0

      服务器响应HTTP/1.1 101,则代表服务器支持http2.0

      服务器响应HTTP/1.1 200,代表不识别Http2.0的请求)

  • 2xx:成功。最典型的是 200(OK)、201(创建成功)。

  • 3xx:重定向。如 301(永久移动)、302(暂时移动)、304(内容未改变)。 对于浏览器来说表现一样,

但是301可以通知搜索引擎,你的网站已迁移,搜索引擎会将权重转移到新域名。
  • 4xx:客户端错误。如 400(客户端请求错误)、401(认证失败)、403(被禁 止)、404(找不到内容)。

  • 5xx:服务器错误。如 500(服务器内部错误)

日常中最重要的2打头 成功,4打头客户端错误。

HTTP的Header和Body

Body是报文的核心,但是所有的Body都是配合Header使用的,提交用户信息有多个方法,都是由Header定义的。

  • Header是Http消息的元数据(metadata) 即数据的数据

相关文章

  • HTTP 基础

    转载自 github:Interview-Notebook,有删减和改动参考:《图解 HTTP》 一 、基础概念 ...

  • http基础

    URL 统一资源定位符(URL)是资源标识符最常见的形式。URL 描述了一台特定服务器上某资源的特定位置。它们可以...

  • HTTP基础

    HTTP:HyperText Transfer Protocol 超文本传输协议 HTTPS:HTTP基于SSL及...

  • http基础

    前言 今天调试的时候用到了curl,所以这周就简单介绍一下curl的用法。curl一般用来发送http请求,进行w...

  • HTTP 基础

    一什么是URL? 1.1URL和URI有什么区别? URI:Uniform resource identifer,...

  • http基础

    1.http协议 1.1 概念 是对浏览器和服务器端数据传输格式的规范! 1.2 http协议内容 请求 响应 2...

  • HTTP 基础

    HTTP 作用 用于客户端和服务器端的通信。 请求资源一方成为客户端,提供资源一方成为服务器端。 有时候,双方角色...

  • http基础

    OSI 七层模型指什么OSI:Open System Interconnection moble。是一个由国际标准...

  • HTTP基础

    本博客著作权归从这到那所有,转载请注明出处 HTTP基础 HTTP:Hyper Text Transfer Pro...

  • HTTP基础

网友评论

      本文标题:Http 基础

      本文链接:https://www.haomeiwen.com/subject/ccbdkktx.html