HTTP 协议

作为web开发人员,了解一些http协议的知识很有必要。本文简单介绍了HTTP协议的知识,若有错误的地方,望大家指正。

1.HTTP协议是什么?

  • http协议是一个应用层的协议。规定了浏览器和服务器之间的通信规范。通常用TCP连接方式。

2.HTTP 1.0、1.1 连接的方式。

  • 在HTTP 1.0 中,浏览器和服务器使用的是短连接,响应完,立即断开。
  • 请求的过程:3次握手,请求,响应,断开连接。
  • http不保存连接,好处:服务器可以处理更多的连接,但是每次建立连接会降低处理速度。
  • 现在主流的版本是HTTP 1.1 ,在HTTP 1.1 中我们使用长连接,一个请求结束后,不断开,继续请求。

3.HTTP协议的URL

URL的格式:

http://host[":"port][abs_path]

  • host: 代表主机域名或IP地址
  • port: 端口号,缺省端口80
  • abs_path : 请求资源的URL,如果没有,填 "/",通常浏览器会帮我们自动完成。
    EG:
    1、输入:www.cnblogs.com
    浏览器自动转换成:http://www.cnblogs.com/

4. HTTP请求

4.1 请求报文格式:

  • HTTP的请求由3部分组成:请求行、请求头、请求体。
  • SP代表空格、CRLF代表换行
  • 浏览器必须以这个格式发送请求,服务器才能正常解析和响应。

4.2 请求报文示例

4.3 请求方法

  • GET 请求获取Request-URI所标识的资源
  • POST 在Request-URI所标识的资源后附加新的数据,常用于提交表单。
  • HEAD 请求获取由Request-URI所标识的资源的响应消息报头
  • PUT 请求服务器存储一个资源,并用Request-URI作为其标识
  • DELETE 请求服务器删除Request-URI所标识的资源
  • TRACE 请求服务器回送收到的请求信息,主要用于测试或诊断
  • CONNECT 保留将来使用
  • OPTIONS 请求查询服务器的性能,或者查询与资源相关的选项和需求

get和post是最常用的方法,简单来说,前者用于获取数据,后者用于提交数据。

5. HTTP响应

5.1 响应报文格式:

  • HTTP的响应也是由3个部分组成:响应行、响应头,响应体
  • 响应行:status code 表示响应的状态码,description是描述信息。
  • 同样 SP代表空格、CRLF代表换行,
  • 响应必须以这种规范格式发送给浏览器,浏览器才能正常解析并显示。

5.2 响应报文示例

5.3响应码

200段是成功;300段需要对请求做进一步的处理;400段表示客户端请求错误;500段是服务器的错误
常见响应码:

  • "200" : OK
  • "302" : Found 重定向.
  • "400" : Bad Request 错误请求,发出错误的不符合Http协议的请求
  • "403" : Forbidden 禁止
  • "404" : Not Found 未找到。演示访问一个不存在的页面看报文
  • "500" : Internal Server Error 服务器内部错误。演示页面抛出异常。
  • "503" : Service Unavailable。一般是访问人数过多。

PS:会在文章的末尾为大家提供一份HTTP状态码大全的文档。

6. HTTP消息报头

HTTP消息报头分4类:普通报头、请求报头、响应报头、实体报头
每一个报头域都是由名字+“:”+空格+值 组成,消息报头域的名字是大小写无关的。

6.1 普通报头

应用于所有请求和响应消息且和请求体与响应体无关的信息就存放在普通报头中。

  • Cache-Control: no-cache (用于指示请求或响应消息不能缓存)
  • Date 普通报头域表示消息产生的日期和时间
  • Connection: close/keep-alive (是否开启长连接)

6.2 请求报头

客户端向服务器端传递请求的附加信息以及客户端自身的信息存放在请求报头
常用的请求报头:

  • Accept: text/html,application/xhtml+xml,application/xml; 指定客户端接受哪些类型的信息。
  • Accept-Charset: iso-8859-1,gb2312 客户端接受的字符集 (缺省是任何字符集都可以接受。)
  • Accept-Encoding: gzip,deflate,sdch 可接受的内容编码。 (缺省是各种内容编码都可以接受。)
  • Accept-Language: zh-CN,zh 指定语言。(缺省各种语言都可以接受。)
  • Authorization 用于证明客户端有权查看某个资源
  • Host: www.cnblogs.com 被请求资源的Internet主机和端口号 (缺省端口号:80) 这个报头是必需的
  • User-Agent: Mozilla/4.0(compatible;MSIE6.0;Windows NT 5.0) 操作系统、浏览器和其它属性

6.2 响应报头

响应报头允许服务器传递不能放在状态行中的附加响应信息,以及关于服务器的信息和对Request-URI所标识的资源进行下一步访问的信息。
常用的响应报头:

  • Location 响应报头域用于重定向接受者到一个新的位置
  • Server:Apache-Coyote/1.1 服务器信息

6.3 实体报头

请求和响应消息都可以传送一个实体。
常用的实体报头:

  • Content-Encoding: gzip 内容编码
  • Content-Language: zh-CN 语言
  • Content-Length: 10 实体正文的长度
  • Content-Type: text/html;charset=GB2312 返回数据的类型
  • Last-Modified 实体报头域用于指示资源的最后修改日期和时间。
  • Expires:Thu,15 Sep 2006 16:23:12 GMT 响应过期的日期和时间。

参考文献

HTTP协议详解
HTTP 状态码大全文档下载
Content-Type文档下载

http协议知识整理的更多相关文章

  1. http协议知识整理(转)

    HTTP 协议 作为web开发人员,了解一些http协议的知识很有必要.本文简单介绍了HTTP协议的知识,若有错误的地方,望大家指正. 1.HTTP协议是什么? http协议是一个应用层的协议.规定了 ...

  2. Kali Linux渗透基础知识整理(二)漏洞扫描

    Kali Linux渗透基础知识整理系列文章回顾 漏洞扫描 网络流量 Nmap Hping3 Nessus whatweb DirBuster joomscan WPScan 网络流量 网络流量就是网 ...

  3. wifi基础知识整理

    转自 :http://blog.chinaunix.net/uid-9525959-id-3326047.html WIFI基本知识整理 这里对wifi的802.11协议中比较常见的知识做一个基本的总 ...

  4. 【OGG】OGG基础知识整理

    [OGG]OGG基础知识整理 一.GoldenGate介绍 GoldenGate软件是一种基于日志的结构化数据复制软件.GoldenGate 能够实现大量交易数据的实时捕捉.变换和投递,实现源数据库与 ...

  5. 【转】WIFI基本知识整理

    WIFI基本知识整理 这里对wifi的802.11协议中比较常见的知识做一个基本的总结和整理,便于后续的学习.因为无线网络中涉及术语很多,并且许多协议都是用英文描述,所以有些地方翻译出来会有歧义,这种 ...

  6. [转帖]NSA武器库知识整理

    NSA武器库知识整理 https://www.cnblogs.com/FrostDeng/p/7120812.html 美国国家安全局(NSA)旗下的“方程式黑客组织”(shadow brokers) ...

  7. Redis相关知识整理

    Redis相关知识整理 1. Redis和MySQL的区别?a).mysql是关系型数据库,而redis是NOSQL,非关系型数据库.mysql将数据持久化到硬盘,读取数据慢,而redis数据先存储在 ...

  8. js事件(Event)知识整理

    事件(Event)知识整理,本文由网上资料整理而来,需要的朋友可以参考下   鼠标事件 鼠标移动到目标元素上的那一刻,首先触发mouseover 之后如果光标继续在元素上移动,则不断触发mousemo ...

  9. Kali Linux渗透基础知识整理(四):维持访问

    Kali Linux渗透基础知识整理系列文章回顾 维持访问 在获得了目标系统的访问权之后,攻击者需要进一步维持这一访问权限.使用木马程序.后门程序和rootkit来达到这一目的.维持访问是一种艺术形式 ...

随机推荐

  1. RunLoop Note

    I. Begin from Apple Document Apple describes the priciples of runloop in Threading Programming Guide ...

  2. 请教下 f = f.replace('\n', '\r')这条没起作用

    !/usr/bin/env python -- coding: utf-8 -- import json import string import sys reload(sys) sys.setdef ...

  3. Vue 备

    <div id="app"> <span :class='{red:addClass}'>jam</span> </div> < ...

  4. 使用location.hash保存页面状态

    hash 属性是一个可读可写的字符串,该字符串是 URL 的锚部分(从 # 号开始的部分). 语法 location.hash 在我们的项目中,有大量ajax查询表单+结果列表的页面,由于查询结果是a ...

  5. UTF-8文件的Unicode签名BOM(Byte Order Mark)问题记录(EF BB BF)

    背景 楼主测试的批量发送信息功能上线之后,后台发现存在少量的ERROR日志,日志内容为手机号码格式不正确. 此前测试过程中没有出现过此类问题,从运营人员拿到的发送列表的TXT,号码是符合规则的,且格式 ...

  6. 【Python】模块学习之Timer定时任务,递归定时自调获取博客浏览量

    Timer定时任务 下面是Timer函数的官方doc介绍信息 """ Call a function after a specified number of second ...

  7. pip 批量更新

    1. pip3 list --outdated >> requests  现将要更新的列表写入requests 2.对文件中的数据进行处理 Package        Version   ...

  8. 【转至nmap】nc命令

    什么是nc nc是netcat的简写,有着网络界的瑞士军刀美誉.因为它短小精悍.功能实用,被设计为一个简单.可靠的网络工具 nc的作用 (1)实现任意TCP/UDP端口的侦听,nc可以作为server ...

  9. HDU 4815 概率dp,背包

    Little Tiger vs. Deep Monkey Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65535/65535 K ( ...

  10. 三大平衡树(Treap + Splay + SBT)总结+模板

    Treap树 核心是 利用随机数的二叉排序树的各种操作复杂度平均为O(lgn) Treap模板: #include <cstdio> #include <cstring> #i ...