当前位置: 首页 > news >正文

HTTP协议-HTTP响应报文

目前网络应用都是用TCP/IP协议进行通信的。而在网络通信中使用最多的web协议就是基于TCP的HTTP协议,由此可见http的重要性。

TCP协议与HTTP协议

首先我们先分别来了解一下,TCP协议和HTTP协议

TCP协议

TCP(Transmission Control Protocol 传输控制协议)是一种面向连接(连接导向)的、可靠的、 基于IP的传输层协议,是互联网的基础。许多应用层协议都是基于TCP构建,典型的是HTTP、SMIP等协议。

TCP在OSI模型中属于传输协议。首先来看看OSI的七层模型:

HTTP协议

HTTP全称是HyperText Transfer Protocol,即:超文本传输协议,从1990年开始就在WWW上广泛应用,是现今在WWW上应用最多的协议, Http是应用层协议,当你上网浏览网页的时候,浏览器和Web服务器之间就会通过HTTP在Internet上进行数据的发送和接收。

HTTP它是属于TCP上层的协议,但是本身并无会话的特点,它是一个基于请求/响应模式的、无状态的协议,以一问一答的方式实现服务。即我们通常所说的Request/Response。

那么TCP与HTTP协议两者之间究竟在网络通信中起到什么作用以及有什么联系呢?下面我们通过 一张图展示在浏览器上访问一个网页,各种协议在里面起的作用就能找到答案。

HTTP请求报文

一个请求报文有以下四个部分组成:请求行(request line)消息头部(header)空行请求正文

如下请求报文:

POST /index.html HTTP/1.1
HOST: www.XXX.com
User-Agent: Mozilla/5.0(Windows NT 6.1;rv:15.0) Firefox/15.0

Username=admin&password=admin
复制代码
1. 请求行

请求行由请求方法URLHTTP协议版本3个字段组成,它们用空格分隔。

例如:

GET /index.html HTTP/1.1
复制代码

HTTP协议的请求方法有:

  • GET 获取资源
  • POST 向服务器端发送数据,传输实体主体
  • PUT 传输文件
  • HEAD 获取报文首部
  • DELETE 删除文件
  • OPTIONS 询问支持的方法
  • TRACE 追踪路径
2. 请求头部

请求头部由关键字/值对组成,每行一对,关键字和值用英文冒号“:”分隔。请求头部通知服务器有关于客户端请求的信息,

  • 通用首部(General Header)
  • 请求首部(Request Header)
  • 响应首部(Response Header)
  • 实体首部(Entity Header Fields)

如下图:

其中典型的请求头有:

User-Agent:产生请求的浏览器类型。
Accept:客户端可识别的内容类型列表。
Host:请求的主机名,允许多个域名同处一个IP地址,即虚拟主机。
复制代码
3. 空行

最后一个请求头之后是一个空行,发送回车符和换行符,通知服务器以下不再有请求头。

4. 请求数据

请求数据不在GET方法中使用,而是在POST方法中使用。POST方法适用于需要客户填写表单的场合。与请求数据相关的最常使用的请求头是Content-Type和Content-Length。

HTTP响应报文

HTTP响应也由四个部分组成,分别是:响应行响应头空行响应体

如下响应报文所示:

HTTP/1.1 200 OK
Content-Encoding: gzip
Content-Type: text/html;charset=utf-8

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8" />
    <title>Document</title>
</head>
<body>
    <p>this is http response</p>
</body>
</html>
复制代码

正如你所见,在响应中唯一真正的区别在于第一行中用状态信息代替了请求信息。状态行(status line)通过提供一个状态码来说明所请求的资源情况。

1. 状态行

状态行 : HTTP-Version Status-Code Reason-Phrase CRLF

  • HTTP-Version 服务器HTTP协议的版本
  • Status-Code 服务器发回的响应状态代码
  • Reason-Phrase 状态代码的文本描述

状态码 :状态码负责表示客户端请求的返回结果、标记服务器端是否正常、通知出现的错误。状态代码由三位数字组成,第一个数字定义了响应的类别,且有五种可能取值

状态码含义
1xx指示信息--表示请求已接收,继续处理
3xx重定向--要完成请求必须进行更进一步的操作
4xx客户端错误--请求有语法错误或请求无法实现
5xx服务器端错误--服务器未能实现合法的请求
3xx重定向--要完成请求必须进行更进一步的操作

常见状态代码、状态描述的说明如下。 200 OK:客户端请求成功。 400 Bad Request:客户端请求有语法错误,不能被服务器所理解。 401 Unauthorized:请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用。 403 Forbidden:服务器收到请求,但是拒绝提供服务。 404 Not Found:请求资源不存在,举个例子:输入了错误的URL。 500 Internal Server Error:服务器发生不可预期的错误。 503 Server Unavailable:服务器当前不能处理客户端的请求,一段时间后可能恢复正常,举个例子:HTTP/1.1 200 OK(CRLF)。

  • 2XX 成功
状态码含义
200OK 客户端发过来的数据被正常处理
204Not Content 正常响应,没有实体
206Partial Content范围请求,返回部分数据,响应报文中由Content-Range指定实体内容
  • 3XX 重定向功
状态码含义
301Moved Permanently 永久重定向
302Found 临时重定向,规范要求方法名不变,但是都会改变
303See Other 和302类似,但必须用GET方法
304Not Modified 状态未改变 配合(If-Match、If-Modified-Since、If-None_Match、If-Range、If-Unmodified-Since)
307Temporary Redirect 临时重定向,不该改变请求方法
  • 4XX 客户端错误
状态码含义
400Bad Request 请求报文语法错误
401unauthorized 需要认证
403Forbidden 服务器拒绝访问对应的资源
404Not Found 服务器上无法找到资源
  • 5XX 服务器端错误
状态码含义
500Internal Server Error 服务器故障
503Service Unavailable 服务器处于超负载或正在停机维护

HTTP首部

  • 通用首部字段
首部字段名说明
Cache-Control控制缓存行为
Connection链接的管理
Date报文日期
Pragma报文指令
Trailer报文尾部的首部
Trasfer-Encoding指定报文主体的传输编码方式
Upgrade升级为其他协议
Via代理服务器信息
Warning错误通知
  • 请求首部字段
首部字段名说明
Accept用户代理可处理的媒体类型
Accept-Charset优先的字符集
Accept-EncodingAccept-Encoding
Accept-Langulage优先的语言
AuthorizationWeb认证信息
Expect期待服务器的特定行为
From用户的电子邮箱地址
Host请求资源所在的服务器
If-Match比较实体标记
If-Modified-Since比较资源的更新时间
If-None-Match比较实体标记
If-Range资源未更新时发送实体Byte的范围请求
If-Unmodified-Since比较资源的更新时间(和If-Modified-Since相反)
Max-Forwards最大传输跳数
Proxy-Authorization代理服务器需要客户端认证
Range实体字节范围请求
Referer请求中的URI的原始获取方
TE传输编码的优先级
User-AgentHTTP客户端程序的信息

相关文章:

  • 《以太坊白皮书》笔记(3)—— 以太坊介绍. 下
  • zookeeper的开启启动
  • js拦截全局ajax请求
  • Redis Exception: Exceeded timeout of 00:00:03
  • oracle安装注意
  • Vue-cli(四) Vue文件
  • 深度学习将让图像处理变得简单通用
  • Android单元测试
  • Vue2.0增删改查案例(Vue+Less+LocalStorage)
  • Python入门之文件基本操作和函数入门
  • GitUp, 你不可错过的秀外慧中的git工具
  • Windows + IDEA + SBT 打造Spark源码阅读环境
  • Node:异步编程
  • NO12 useradd-passwd-uname-hostname命令-上传rz下载sz-批量部署- Linux用户相关操作
  • 在Laravel中创建自己的PHP帮助函数
  • 3.7、@ResponseBody 和 @RestController
  • Fundebug计费标准解释:事件数是如何定义的?
  • Hexo+码云+git快速搭建免费的静态Blog
  • IOS评论框不贴底(ios12新bug)
  • java8-模拟hadoop
  • JS创建对象模式及其对象原型链探究(一):Object模式
  • Linux下的乱码问题
  • MD5加密原理解析及OC版原理实现
  • Mocha测试初探
  • Phpstorm怎样批量删除空行?
  • PHP面试之三:MySQL数据库
  • Python 基础起步 (十) 什么叫函数?
  • Synchronized 关键字使用、底层原理、JDK1.6 之后的底层优化以及 和ReenTrantLock 的对比...
  • tab.js分享及浏览器兼容性问题汇总
  • V4L2视频输入框架概述
  • vue从入门到进阶:计算属性computed与侦听器watch(三)
  • webpack+react项目初体验——记录我的webpack环境配置
  • 代理模式
  • 精彩代码 vue.js
  • 如何设计一个微型分布式架构?
  • 数据科学 第 3 章 11 字符串处理
  • 算法之不定期更新(一)(2018-04-12)
  • 用Canvas画一棵二叉树
  • 职业生涯 一个六年开发经验的女程序员的心声。
  • ​LeetCode解法汇总2182. 构造限制重复的字符串
  • #调用传感器数据_Flink使用函数之监控传感器温度上升提醒
  • $.ajax()参数及用法
  • (1)Android开发优化---------UI优化
  • (八)五种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
  • (第一天)包装对象、作用域、创建对象
  • (附源码)springboot掌上博客系统 毕业设计063131
  • (附源码)计算机毕业设计SSM基于java的云顶博客系统
  • (官网安装) 基于CentOS 7安装MangoDB和MangoDB Shell
  • (十三)Maven插件解析运行机制
  • (实战)静默dbca安装创建数据库 --参数说明+举例
  • (转)eclipse内存溢出设置 -Xms212m -Xmx804m -XX:PermSize=250M -XX:MaxPermSize=356m
  • (转)Linux下编译安装log4cxx
  • (转)socket Aio demo
  • .NET Micro Framework初体验
  • .net 使用ajax控件后如何调用前端脚本