http协议正文.docx
- 文档编号:25874601
- 上传时间:2023-06-16
- 格式:DOCX
- 页数:10
- 大小:18.57KB
http协议正文.docx
《http协议正文.docx》由会员分享,可在线阅读,更多相关《http协议正文.docx(10页珍藏版)》请在冰豆网上搜索。
http协议正文
竭诚为您提供优质文档/双击可除
http协议正文
篇一:
http协议
http协议详解
引言
http是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。
它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展。
目前在www中使用的是http/1.0的第六版,http/1.1的规范化工作正在进行之中,而且http-ng(nextgenerationofhttp)的建议已经提出。
http协议的主要特点可概括如下:
1.支持客户/服务器模式。
2.简单快速:
客户向服务器请求服务时,只需传送请求方法和路径。
请求方法常用的有get、head、post。
每种方法规定了客户与服务器联系的类型不同。
由于http协议简单,使得http服务器的程序规模小,因而通信速度很快。
3.灵活:
http允许传输任意类型的数据对象。
正在传输的类型由content-type加以标记。
4.无连接:
无连接的含义是限制每次连接只处理一个请求。
服务器处理完客户的请求,并收到客户的应答后,即断开连接。
采用这种方式可以节省传输时间。
5.无状态:
http协议是无状态协议。
无状态是指协议对于事务处理没有记忆能力。
缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。
另一方面,在服务器不需要先前信息时它的应答就较快。
一、http协议详解之uRl篇
http(超文本传输协议)是一个基于请求与响应模式的、无状态的、应用层的协议,常基于tcp的连接方式,http1.1版本中给出一种持续连接的机制,绝大多数的web开发,都是构建在http协议之上的web应用。
httpuRl(uRl是一种特殊类型的uRi,包含了用于查找某个资源的足够的信息)的格式如下:
http:
//host[":
"port][abs_path]
http表示要通过http协议来定位网络资源;host表示合法的internet主机域名或者ip地址;port指定一个端口号,为空则使用缺省端口80;abs_path指定请求资源的uRi;如果uRl中没有给出abs_path,那么当它作为请求uRi时,必须以“/”的形式给出,通常这个工作浏览器自动帮我们完成。
eg:
1、输入:
浏览器自动转换成:
http:
///
2、http:
192.168.0.116:
8080/index.jsp
二、http协议详解之请求篇
http请求由三部分组成,分别是:
请求行、消息报头、请求正文
1、请求行以一个方法符号开头,以空格分开,后面跟着请求的uRi和协议的版本,格式如下:
methodRequest-uRihttp-VersioncRlF
其中method表示请求方法;Request-uRi是一个统一资源标识符;http-Version表示请求的http协议版本;cRlF表示回车和换行(除了作为结尾的cRlF外,不允许出现单独的cR或lF字符)。
请求方法(所有方法全为大写)有多种,各个方法的解释如下:
get请求获取Request-uRi所标识的资源
post在Request-uRi所标识的资源后附加新的数据
head请求获取由Request-uRi所标识的资源的响应消息报头
put请求服务器存储一个资源,并用Request-uRi作为其标识delete请求服务器删除Request-uRi所标识的资源
tRace请求服务器回送收到的请求信息,主要用于测试或诊断
connect保留将来使用
options请求查询服务器的性能,或者查询与资源相关的选项和需求
应用举例:
get方法:
在浏览器的地址栏中输入网址的方式访问网页时,浏览器采用get方法向服务器获取资源,eg:
get/form.htmlhttp/1.1(cRlF)
post方法要求被请求服务器接受附在请求后面的数据,常用于提交表单。
eg:
post/reg.jsphttp/(cRlF)
accept:
image/gif,image/x-xbit,...(cRlF)
...
host:
(cRlF)
content-length:
22(cRlF)
connection:
keep-alive(cRlF)
cache-control:
no-cache(cRlF)
(cRlF)//该cRlF表示消息报头已经结束,在此之前为消息报头
user=jeffrey
响应时的缓存指令包括:
public、private、no-cache、no-store、no-transform、must-revalidate、proxy-revalidate、max-age、s-maxage.
eg:
为了指示ie浏览器(客户端)不要缓存页面,服务器端的jsp程序可以编写如下:
response.sehheader("cache-control","no-cache");
//response.setheader("pragma","no-cache");作用相当于上述代码,通常两者//合用
这句代码将在发送的响应消息中设置普通报头域:
cache-control:
no-cache
date普通报头域表示消息产生的日期和时间
connection普通报头域允许发送指定连接的选项。
例如指定连接是连续,或者指定“close”选项,通知服务器,在响应完成后,关闭连接
2、请求报头
请求报头允许客户端向服务器端传递请求的附加信息以及客户端自身的信息。
常用的请求报头
accept
accept请求报头域用于指定客户端接受哪些类型的信息。
eg:
accept:
image/gif,表明客户端希望接受giF图象格式的资源;accept:
text/html,表明客户端希望接受html文本。
accept-charset
accept-charset请求报头域用于指定客户端接受的字符集。
eg:
accept-charset:
iso-8859-1,gb2312.如果在请求消息中没有设置这个域,缺省是任何字符集都可以接受。
accept-encoding
accept-encoding请求报头域类似于accept,但是它是用于指定可接受的内容编码。
eg:
accept-encoding:
gzip.deflate.如果请求消息中没有设置这个域服务器假定客户端对各种内容编码都可以接受。
accept-language
accept-language请求报头域类似于accept,但是它是用于指定一种自然语言。
eg:
accept-language:
zh-cn.如果请求消息中没有设置这个报头域,服务器假定客户端对各种语言都可以接受。
authorization
authorization请求报头域主要用于证明客户端有权查看某个资源。
当浏览器访问一个页面时,如果收到服务器的响应代码为401(未授权),可以发送一个包
含authorization请求报头域的请求,要求服务器对其进行验证。
host(发送请求时,该报头域是必需的)
host请求报头域主要用于指定被请求资源的internet主机和端口号,它通常从httpuRl中提取出来的,eg:
我们在浏览器中输入:
http:
///index.html
浏览器发送的请求消息中,就会包含host请求报头域,如下:
host:
此处使用缺省端口号80,若指定了端口号,则变成:
host:
:
指定端口号
user-agent
我们上网登陆论坛的时候,往往会看到一些欢迎信息,其中列出了你的操作系统的名称和版本,你所使用的浏览器的名称和版本,这往往让很多人感到很神奇,实际上,服务器应用程序就是从user-agent这个请求报头域中获取到这些信息。
user-agent请求报头域允许客户端将它的操作系统、浏览器和其它属性告诉服务器。
不过,这个报头域不是必需的,如果我们自己编写一个浏览器,不使用user-agent请求报头域,那么服务器端就无法得知我们的信息了。
请求报头举例:
get/form.htmlhttp/1.1(cRlF)
accept:
image/gif,image/x-xbitmap,image/jpeg,application/x-shockwave-flash,application/vnd.ms-excel,application/vnd.ms-powerpoint,application/msword,*/*(cRlF)
accept-language:
zh-cn(cRlF)
accept-encoding:
gzip,deflate(cRlF)
if-modified-since:
wed,05jan20xx11:
21:
25gmt(cRlF)
if-none-match:
w/"80b1a4c018f3c41:
8317"(cRlF)
user-agent:
mozilla/4.0(compatible;msie6.0;windowsnt5.0)(cRlF)host:
(cRlF)
connection:
keep-alive(cRlF)
(cRlF)
3、响应报头
响应报头允许服务器传递不能放在状态行中的附加响应信息,以及关于服务器的信息和对Request-uRi所标识的资源进行下一步访问的信息。
常用的响应报头
location
location响应报头域用于重定向接受者到一个新的位置。
location响应报头域常用在更换域名的时候。
server
server响应报头域包含了服务器用来处理请求的软件信息。
与user-agent请求报头域是相对应的。
下面是
server响应报头域的一个例子:
server:
apache-coyote/1.1
www-authenticate
www-authenticate响应报头域必须被包含在401(未授权的)响应消息中,客户
篇二:
1、http协议
http协议
一、http概述
二、http协议特点:
1支持客户/服务器模式(b/s)
通常这里所指的客户端是浏览器
2简单快速
客户向服务器请求服务时,只需传送请求方法和路径,请求方法常用的有get/head/post。
每种方法规定了客户与服务器联系的不同类型。
后面会作详解说明。
3灵活
http协议允许传输任意类型的数据对象,正在传输的类型由context-type加以标记。
通过在head中定义meta标签指定。
4无连接:
无连接的含义是指限制每次连接只处理一个请求服务器修理完客户的请求,并收到客户的应答后,即断开连接。
采用这种方式可以节省传输时间。
5无状态:
http协议是无状态协议。
无状态是指协议对于事务处理没有记忆能力。
缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传递的数据量增大。
另一方面,在服务器不需要先前信息时他的应答就较快。
三、http协议url:
就像每家每户都有一个门牌地址一样,每个网页也都有一个internet地址。
当你在浏览器的地址框中输入一个uRl或是单击一个超级链接时,uRl就确定了要浏览的地址。
浏览器通过超文本传输协议(http),将web服务器上站点的网页代码提取出来,并翻译成漂亮的网页。
uRl由三部分组成:
资源类型、存放资源的主机域名、资源文件名。
一个常用的url地址如下:
:
80/server/index.html下面我们对这个url进行详细说明.1、[]这一部分是说明这个请求是基于http协议的,这里请大家注意,我们日常使用的浏览器默认都是基于http协议的所以这一部分内容我们可以省略,浏览器会自动处理。
2、这部分内容表示我们请求的http服务器的域名,这个域名最终会解析为一个ip地址,指向网络中的一台http服务器计算机
3、[]:
这里指的是端口号,必须是一个整数,http协议的默认端口号是80,如果服务器部署的端口号是80那么这里可以省略,web浏览器会自动加上80端口。
如果说我们服务器地址是我们的门牌号,那么端口号就可以说是房间号。
4、:
表示服务器上的一个目录,也可以说是在服务器上部署的一个应用程序。
5、服务器最终会返回给客户端的结果文件,这里是一个html网页.
四、http请求协议
2.1get请求
2.2post请求
五、http响应协议
4.1http响应格式和说明
篇三:
http协议
引言
http是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。
它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展。
目前在www中使用的是http/1.0的第六版,http/1.1的规范化工作正在进行之中,而且http-ng(nextgenerationofhttp)的建议已经提出。
http协议的主要特点可概括如下:
1.支持客户/服务器模式。
2.简单快速:
客户向服务器请求服务时,只需传送请求方法和路径。
请求方法常用的有get、head、post。
每种方法规定了客户与服务器联系的类型不同。
由于http协议简单,使得http服务器的程序规模小,因而通信速度很快。
3.灵活:
http允许传输任意类型的数据对象。
正在传输的类型由content-type加以标记。
4.无连接:
无连接的含义是限制每次连接只处理一个请求。
服务器处理完客户的请求,并收到客户的应答后,即断开连接。
采用这种方式可以节省传输时间。
5.无状态:
http协议是无状态协议。
无状态是指协议对于事务处理没有记忆能力。
缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。
另一方面,在服务器不需要先前信息时它的应答就较快。
一、http协议详解之uRl篇
http(超文本传输协议)是一个基于请求与响应模式的、无状态的、应用层的协议,常基于tcp的连接方式,http1.1版本中给出一种持续连接的机制
,绝大多数的web开发,都是构建在http协议之上的web应用。
httpuRl(uRl是一种特殊类型的uRi,包含了用于查找某个资源的足够的信息)的格式如下:
http:
//host[":
"port][abs_path]
http表示要通过http协议来定位网络资源;host表示合法的internet主机域名或者ip地址;port指定一个端口号,为空则使用缺省端口80;abs_path指定请求资源的uRi;如果uRl中没有给出abs_path,那么当它作为请求uRi时,必须以“/”的形式给出,通常这个工作浏览器自动帮我们完成。
eg:
1、输入:
浏览器自动转换成:
http:
///
2、http:
192.168.0.116:
8080/index.jsp
二、http协议详解之请求篇
http请求由三部分组成,分别是:
请求行、消息报头、请求正文
1、请求行以一个方法符号开头,以空格分开,后面跟着请求的uRi和协议的版本,格式如下:
methodRequest-uRihttp-VersioncRlF
其中method表示请求方法;Request-uRi是一个统一资源标识符;http-Version表示请求的http协议版本;cRlF表示回车和换行(除了作为结尾的cRlF外,不允许出现单独的cR或lF字符)。
请求方法(所有方法全为大写)有多种,各个方法的解释如下:
get请求获取Request-uRi所标识的资源
post在Request-uRi所标识的资源后附加新的数据
head请求获取由Request-uRi所标识的资源的响应消息报头
put请求服务器存储一个资源,并用Request-uRi作为其标识
delete请求服务器删除Request-uRi所标识的资源
tRace请求服务器回送收到的请求信息,主要用于测试或诊断
connect保留将来使用
options请求查询服务器的性能,或者查询与资源相关的选项和需求
应用举例:
get方法:
在浏览器的地址栏中输入网址的方式访问网页时,浏览器采用get方法向服务器获取资源,eg:
get/form.htmlhttp/1.1(cRlF)
post方法要求被请求服务器接受附在请求后面的数据,常用于提交表单。
eg:
post/reg.jsphttp/(cRlF)
accept:
image/gif,image/x-xbit,...(cRlF)
...
host:
(cRlF)
content-length:
22(cRlF)
connection:
keep-alive(cRlF)
cache-control:
no-cache(cRlF)
(cRlF)//该cRlF表示消息报头已经结束,在此之前为消息报头
user=jeffrey
响应时的缓存指令包括:
public、private、no-cache、no-store、no-transform、must-revalidate、proxy-revalidate、max-age、s-maxage.
eg:
为了指示ie浏览器(客户端)不要缓存页面,服务器端的jsp程序可以编写如下:
response.sehheader("cache-control","no-cache");
//response.setheader("pragma","no-cache");作用相当于上述代码,通常两者//合用这句代码将在发送的响应消息中设置普通报头域:
cache-control:
no-cache
date普通报头域表示消息产生的日期和时间
connection普通报头域允许发送指定连接的选项。
例如指定连接是连续,或者指定“close”选项,通知服务器,在响应完成后,关闭连接
2、请求报头
请求报头允许客户端向服务器端传递请求的附加信息以及客户端自身的信息。
常用的请求报头
accept
accept请求报头域用于指定客户端接受哪些类型的信息。
eg:
accept:
image/gif,表明客户端希望接受giF图象格式的资源;accept:
text/html,表明客户端希望接受html文本。
accept-charset
accept-charset请求报头域用于指定客户端接受的字符集。
eg:
accept-charset:
iso-8859-1,gb2312.如果在请求消息中没有设置这个域,缺省是任何字符集都可以接受。
accept-encoding
accept-encoding请求报头域类似于accept,但是它是用于指定可接受的内容编码。
eg:
accept-encoding:
gzip.deflate.如果请求消息中没有设置这个域服务器假定客户端对各种内容编码都可以接受。
accept-language
accept-language请求报头域类似于accept,但是它是用于指定一种自然语言。
eg:
accept-language:
zh-cn.如果请求消息中没有设置这个报头域,服务器假定客户端对各种语言都可以接受。
authorization
authorization请求报头域主要用于证明客户端有权查看某个资源。
当浏览器访问一个页面时,如果收到服务器的响应代码为401(未授权),可以发送一个包含authorization请求报头域的请求,要求服务器对其进行验证。
host(发送请求时,该报头域是必需的)
host请求报头域主要用于指定被请求资源的internet主机和端口号,它通常从httpuRl中提取出来的,eg:
我们在浏览器中输入:
http:
///index.html
浏览器发送的请求消息中,就会包含host请求报头域,如下:
host:
此处使用缺省端口号80,若指定了端口号,则变成:
host:
:
指定端口号user-agent
我们上网登陆论坛的时候,往往会看到一些欢迎信息,其中列出了你的操作系统的名称和版本,你所使用的浏览器的名称和版本,这往往让很多人感到很神奇,实际上,服务器应用程序就是从user-agent这个请求报头域中获取到这些信息。
user-agent请求报头域允许客户端将它的操作系统、浏览器和其它属性告诉服务器。
不过,这个报头域不是必需的,如果我们自己编写一个浏览器,不使用user-agent请求报头域,那么服务器端就无法得知我们的信息了。
请求报头举例:
get/form.htmlhttp/1.1(cRlF)
accept:
image/gif,image/x-xbitmap,image/jpeg,application/x-shockwave-flash,application/vnd.ms-excel,application/vnd.ms-powerpoint,application/msword,*/*(cRlF)accept-language:
zh-cn(cRlF)
accept-encoding:
gzip,deflate(cRlF)
if-modified-since:
wed,05jan20xx11:
21:
25gmt(cRlF)
if-none-match:
w/"80b1a4c018f3c41:
8317"(cRlF)
user-agent:
mozilla/4.0(compatible;msie6.0;windowsnt5.0)(cRlF)
host:
(cRlF)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- http 协议 正文