您的位置:首页 > 理论基础 > 计算机网络

HTTP协议详解

2016-04-27 13:09 381 查看
•1HTTP相关知识

1.1 HTTP简介——HTTP简介

•WEB浏览器与WEB服务器之间的一问一答的交互过程必须遵循一定的规则,这个规则就是HTTP协议。

•HTTP是 hypertexttransfer protocol(超文本传输协议)的简写,它是TCP/IP协议集中的一个应用层协议,用于定义WEB浏览器与WEB服务器之间交换数据的过程以及数据本身的格式。

•HTTP协议的版本HTTP/1.0、HTTP/1.1、HTTP-NG 1.2 HTTP相关知识(2)——HTTP的会话方式

•四个步骤:



浏览器到WEB服务器之间的所有通讯都是完全独立分开的请求和响应对。

1.3 HTTP相关知识(3)—— HTTP1.0与HTTP1.1




•2HTTP请求

2.1HTTP请求(1)——概述

1.请求行

2.若干消息头

3.实体内容(可能没有),如下所示:



2.2 HTTP请求(2) ——请求行

[b]2.3 HTTP请求(3) ——请求消息头(请求头)

2.4 HTTP请求(4) ——请求体[/b]

• GET请求:没有请求体

• POST请求:如果form表单提交的方式为post,则表单项的数据以请求体的形式发送给服务器,没有大小限制

•3HTTP响应

[b]3.1 HTTP
响应(1)——概述[/b]

一个状态行

若干消息头(响应头)

实体内容 (响应体)

[b]3.2 HTTP响应(2)响应状态行[/b]

•状态行

•状态码用于表示服务器对请求的处理结果,它是一个三位的十进制数。响应状态码分为5类,如下所示:



3.3 HTTP响应(3) ——响应消息头(响应头)

3.4 HTTP响应(4) ——响应体

浏览器与WEB服务器的连接过程是短暂的,每次连接只处理一个请求和响应。对每一个页面的访问,浏览器与WEB服务器都要建立一次单独的连接。

请求行中的GET称之为请求方式,请求方式有:

POST、GET、HEAD、OPTIONS、DELETE、TRACE、PUT

常用的有: GET、POST

用户如没有设置,默认情况下浏览器向服务器发送的都是get请求,例如在浏览器直接输地址访问,点超链接访问等都是get,用户如想把请求方式改为post,可通过更改表单的提交方式实现。

不管POST或GET,都用于向服务器请求某个WEB资源,这两种方式的区别主要表现在数据传递上:

如请求方式为GET方式,则可以在请求的URL地址后以?的形式带上交给服务器的数据,多个数据之间以&进行分隔,例如:

GET/mail/1.html?name=abc&password=xyzHTTP/1.1

GET方式的特点:在URL地址后附带的参数是有限制的,其数据容量通常不能超过1K。

如请求方式为POST方式,则可以在请求的实体内容中向服务器发送数据,Post方式的特点:传送的数据量无限制。

常用请求头(浏览器发送给服务器的数据,为了告诉服务器一些情况)

Accept:text/html,image/* 我支持的数据类型

Accept-Charset: utf-8  支持的数据的编码字符集

Accept-Encoding: gzip 支持的压缩方式

Accept-Language: en-us,zh-cn支持的语言

Host: localhost:8888 请求的主机名

Referer: http://www.atguigu.com/index.jsp 发送请求的界面对应的url防盗链
User-Agent: Mozilla/4.0 浏览器的相关信息

Connection:keep-Alive 请求完成后,到是断开呢还是连接着

Date: Tue, 11 Jul 2000 18:23:51 GMT 发送请求的时间

Cookie:tt=123 //后面专门讲



一个HTTP响应代表服务器向客户端回送的数据,它包括:



格式:HTTP版本号 状态码 原因叙述

举例:HTTP/1.1200 OK

响应头(浏览器发送给服务器的数据,为了告诉服务器一些情况):

Location:/day05/index.jsp 告诉浏览器重新定向到指定的路径

Server:apache tomcat 使用的什么web服务器

Content-Encoding: gzip 告诉浏览器我传给你的数据用的压缩方式

Content-Length: 80 响应体的字节数

Content-Language: zh-cn响应体数据的语言

content-type: text/html;charset=GB2312响应体内容的类型 html/css/ image

Last-Modified:Tue, 11 Jul 2000 18:23:51 GMT 资源最后被修改的时间

Refresh: 1定时刷新

Content-Disposition: attachment;filename=aaa.zip提示用户下载

Set-Cookie:SS=Q0=5Lb_nQ; path=/search将cookie数据回送给ie

Expires:-1 告诉浏览器不要缓存起来 

Cache-Control: no-cache

Pragma:no-cache

Connection:close/Keep-Alive 是否保持连接

Date: Tue, 11 Jul 2000 18:23:51 GMT响应的时间

浏览器真正显示的数据,一般情况下为一个html格式的文本,也可以是其它类型的数据
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: