码迷,mamicode.com
首页 > Web开发 > 详细

HTTP协议的URI及各种方法

时间:2016-06-09 22:19:05      阅读:284      评论:0      收藏:0      [点我收藏+]

标签:

每个Web服务器资源都有一个名字,这样客户端就可以说明他们感兴趣的资源是什么了,服务器资

源名被统称为:统一资源标识符(Uniform Resource Identifier, URI)

 

Joe的五金店的Web服务器上一个图片资源的URI:

http://www.joes-hardware.com/specials/saw-blade.gif

 

URI有两种形式,分别为URL和URN,URN仍然处于试验阶段,因此现在所说的URI就是指URL

URL精确地说明了某资源的位置以及如何去访问它,获取资源过程如下:

1:使用HTTP协议,2:进入www.joes-hardware.com主机,3:获取名为/specials/saw-

blade.gif的资源

 

请求方法

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

  HEAD: 与GET方法类似,但服务器在响应中只返回首部,不会返回实体的主题部分

  PUT:向服务器写入文档

  技术分享

PUT方法的语意就是让服务器用请求的主体部分来创建一个由所请求的URL命名的新文档,或者

如果那个URL已经存在的话,就用这个主体来代替它

 

  POST:POST方法起初是用来向服务器输入数据,实际上通常会用它来支持HTML的表单,

表单中填好的数据通常会被送给服务器,然后由服务器将其发送到它要去的地方(比如送到一个服

务器网关程序中,然后由这个程序对其进行处理)

技术分享

 

注意:POST用于向服务器发送数据,PUT用于向服务器上的资源(例如文件)中存储数据

  TRACE:客户端发起一个请求时,这个请求可能要穿过防火墙,代理,网关或其他一些应用

程序,每个节点都可能修改原始的HTTP请求,TRACE方法允许客户端在最终将请求发送给服务

器时,看看它变成了什么样子

TRACE请求会在目的服务器端发起一个“环回”诊断,行程最后一站的服务器会弹回一条TRACE响

应,并在相应主体中携带它收到的原始请求报文,这样客户端就可以查看在所有中间HTTP应用程

序组成的请求/响应链上,原始报文是否,以及如何被毁坏或修改过

技术分享

 

TRACE方法主要用于诊断,验证请求是否如愿穿过了请求/响应链,它是一种很好的工具,可以

用来查看代理和其他应用程序对用户请求所产生的效果

 

尽管TRACE可以方便用于诊断,它的缺点在于它假定中间应用程序对各种不同类型请求(不同方

法--GET,HEAD,POST等)的处理是相同的,很多HTTP应用程序会根据方法的不同做出不同的处

理,比如,代理可能将POST请求直接发送给服务器,而将GET发送给另一个HTTP应用程序(比

如Web缓存),TRACE并不提供区分这些方法的机制,通常中间应用程序会自行决定对TRACE请求

的处理方式

TRACE请求中不能带有实体的主体部分,TRACE响应的实体主体部分包含了响应服务器收到的请

求的精确副本

  OPTIONS:请求服务器告知其支持的各种功能,可以询问服务器通常支持哪些方法,或者对

某些特殊资源支持哪些方法。(有些服务器可能只支持对一些特殊类型的对象使用特定的操作),这

为客户端应用程序提供了一种手段,使其不用实际访问那些资源就能判断访问各资源的最优方式

技术分享 

 

  DELETE:请求服务器删除URL所指定的资源,但是客户端应用程序无法保证输出操作一定会被执行,因为HTTP规范允许服务器在不通知客户端的情况下撤销请求

 

HTTP协议的URI及各种方法

标签:

原文地址:http://www.cnblogs.com/linuxboke/p/5572795.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!