《HTTP权威指南》学习笔记——HTTP报文

HTTP报文

HTTP:互联网的信使

HTTP报文:信使用来搬东西的包裹

1.报文流

HTTP报文:HTTP应用程序之间发送的数据块

组成:元信息开头(文本形式,描述报文的内容和含义)+可选的数据部分。

2.报文的组成部分

三部分组成:

  • 起始行(描述报文)
  • 首部块(属性)
  • 主体部分(主体)

报文的语法:

两类:请求报文和响应报文

请求报文格式:

<method><request-URL><version>
<headers>
<entity-body>

响应报文格式:

<version><status><reason-phrase>
<headers>
<entity-body>
  • 方法 对资源执行的动作 如GET、POST等
  • 请求URL
  • 版本 HTTP版本,如HTTP/1.1
  • 状态码 status-code 描述请求过程中发生的情况
  • 原因短语
  • 首部
  • 实体的主体部分

起始行

请求行:说明要做些什么

响应行:说明发生了什么

方法:告诉服务器做什么事情

状态码:告诉客户端发生了什么

常见状态码:
200 OK 成功
404 Not Found 未找到

原因短语:文本形式的解释,如HTTP/1.0 200 OK,OK就是原因短语

版本号:HTTP/x.y 告知对方自己所遵循的协议版本

首部

起始行后面跟着0,1或多个HTTP首部字段

HTTP首部字段向请求和响应报文中添加一些附加信息

本质是键值对的列表

方法

安全方法

HTTP请求不会在服务器上产生结果,GET方法和HEAD方法就是安全方法

GET

用于请求服务器发送某个资源

HEAD

与GET方法类似,服务器在响应中只返回首部

PUT

向服务器写入文档(GET是从服务器读取文档)

POST

向服务器输入数据,用它来支持HTML表单

POST用于向服务器发送数据,PUT用于向服务器上的资源中存储数据

TRACE

允许客户端在最终将请求发送给服务器时,看看它变成什么样子

3.状态码

HTTP状态码被分成了五大类

3.1 100——199 信息性状态码

HTTP/1.1向协议中引入信息性状态码,这些状态码相对较新,由于复杂性和感知价值存在一些争议,而受到限制。

3.2 200——299 成功状态码

3.3 300——399 重定向状态码

重定向状态码要么告知客户端使用替代位置来访问他们所感兴趣的资源,要么就提供一个替代的响应而不是资源的内容。

304 Not Modified 若客户端发起GET请求,而最近资源未被修改的话
就应该用这个状态码来说明资源未被修改。带有这个状态码的响应不应该包含实体的主体部分。

3.4 400——499 客户端错误状态码

客户端发送一些服务端无法处理的东西,如格式错误的请求报文,不存在的URL


3.5 500——599 服务器错误状态码

客户端发送有效请求,服务器却出错。

首部

首部和方法配合工作,共同决定客户端和服务器能做什么事情。

在请求报文和响应报文中都可以用首部来提供信息。

首部可以分为5个类型:

  • 通用首部 客户端和服务器都可以使用的通用首部,提供一些通用功能
    如 Date:Sat, 13 Feb 2016 12:09:32 GMT
  • 请求首部 请求报文特有的,为服务器提供一些额外的信息
    如 Accept:image/webp,image/*,*/*;q=0.8
  • 响应首部
  • 实体首部 用于应对实体主体部分的首部
    Content-Type:text/plain; charset=utf-8
  • 拓展首部 非标准的首部,由应用程序开发者创建。

原文地址:http://www.cnblogs.com/JohnTsai/p/5188356.html

时间: 2024-08-01 08:50:06

《HTTP权威指南》学习笔记——HTTP报文的相关文章

javascript权威指南 学习笔记之javascript数据类型_javascript技巧

复制代码 代码如下: <!doctype html> <html> <head> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <title>javascript数据类型</title> </head> <body> <script type="text/javasc

javascript权威指南 学习笔记之变量作用域分享_javascript技巧

不知道,大家对语言中变量的"声明"与"定义"是怎么理解的, 我的理解如下: "声明"变量,只是仅仅声明,而"定义"变量,指声明了,并且赋值了. 例如: 复制代码 代码如下: var name;//只是声明 var num = 11;//声明,并且赋值,即定义了 var password = "yangjiang";//声明,并且赋值,即定义了 下面是几点总结: 变量的作用域:全局的和局部的.(注意:如果尝试

javascript权威指南 学习笔记之null和undefined_jquery

复制代码 代码如下: <!doctype html> <html> <head> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <title>javascript之null和undefined</title> </head> <body> <script type="

hadoop权威指南学习(一) - 天气预报MapReduce程序的开发和部署

看过Tom White写的Hadoop权威指南(大象书)的朋友一定得从第一个天气预报的Map Reduce程序所吸引, 殊不知,Tom White大牛虽然在书中写了程序和讲解了原理,但是他以为你们都会部署了,这里轻描淡写给 带过了,这样就给菜鸟们留了课题,其实在跑书中的程序的时候,如果没经验,还是会踩坑的. 这里笔者就把踩过的坑说一下,以防后来人浪费时间了. 1. 首先,你得下载书中的ncdc气象原始数据,这个可以从书中的官网下载. 作者比较做人家,只给了2年的历史数据,无妨,2年也可以运行.

JAVA 2学习指南 学习笔记---------第一章 语言基础知道

JAVA中的关键字都是小写的.共有49个关键字,2个未使用的保留字:const goto; 数据类型: boolean    byte   int    short   long    float    double    char    class    interface 流程控制: if     else    do    while    for    switch    case    default    break    continue    return    try    c

JavaScript权威设计--JavaScript函数(简要学习笔记十一)

1.函数调用的四种方式 第三种:构造函数调用 如果构造函数调用在圆括号内包含一组实参列表,先计算这些实参表达式,然后传入函数内.这和函数调用和方法调用是一致的.但如果构造函数没有形参,JavaScript构造函数调用的语法是允许省略实参列表和圆括号的. 如: var o=new Object(); //->等价于 var o=new Object;   第四种:使用call()与apply()间接调用(放在后面详细说明)   2.函数的实参与形参--可选形参 先看一个例子: function g

JavaScript权威设计--JavaScript函数(简要学习笔记十)

1.函数命名规范 函数命名通常以动词为前缀的词组.通常第一个字符小写.当包含多个单词时,一种约定是将单词以下划线分割,就像"like_Zqz()". 还有一种就是"likeZqz()".有些些函数是用作内部用的或者为私有函数通常以一条下划线为前缀,就像"_zqzName()".   2.以表达式方式定义的函数 如: var zqz=function (){ return "zhaoqize"; } 在使用的时候必须把它赋值给一

Jquery 学习笔记(二)jQuery性能优化指南

Jquery 学习笔记(二) -jQuery性能优化指南 2009年11月30日 一 作者:   邦畿千里   1,总是从ID选择器开始继承 在jQuery中最快的选择器是ID选择器,因为它直接来自于JavaScript的getElementById()方法. 例如有一段HTML代码: <div id="content"> <form method="post" action="#"> <h2>交通信号灯<

《Ext JS权威指南》——1.1节学习Ext JS必需的基础知识

1.1 学习Ext JS必需的基础知识 1. JavaScript 嗯,这个还用说吗?Ext JS本来就是一个JavaScript的框架,而且使用Ext JS就需要使用JavaScript语法来开发,需要JavaScript的知识是必然的了.问题的关键是,开发人员对JavaScript知识的掌握也有深浅之分.譬如,我碰到一些开发人员,对JavaScript算是很熟悉了,但是不会JSON,不会直接使用JSON对象,在使用Ext JS的过程中,需要使用JSON对象的时候,居然是通过组装字符串的方式,