HTTP协议有八种请求类型,下面简单介绍下:
1. OPTIONS:返回服务器针对特定资源所支持的HTTP请求方法。也可以利用向web服务器发送‘*’请求来测试服务器的功能性
2. HEAD:向服务器索要与GET请求相一致的响应,只不过响应体将不会被返回。这一方法可以在不必传输整个响应内容的情况下,就可以获取包含在响应消息头中的元信息
3. GET:向特定的资源发出请求
4. POST:向指定的资源提交数据进行请求处理。例如提交表单或上传文件。数据被包含在请求体中,POST请求可能会导致新的资源的创建和/或已有资源的修改
5. PUT:向指定资源位置上传其最新内容
6. DELETE:请求服务器删除Request-URI所标识的资源
7. TRACE:回显服务器收到的请求,主要用于测试或诊断
8. CONNECT:HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器
HTTP定义了与服务器交互的不同方法,虽然HTTP的请求方式有八种,但最基本的有四种:GET/POST/PUT/DELETE,URL全称是资源描述符,我们可以这样认为:一个URL地址,它用于描述一个网络上的资源,而HTTP中的GET、POST、PUT、DELETE就对应着对这个资源的查、改、增、删四个操作。GET一般用于查询、获取资源信息,而POST一般用于更新资源信息。但我们在实际应用中常用的也就是GET和POST,其他请求方式也都可以通过这两种方式间接来实现。这里主要介绍一下GET和POST。
POST和GET,这两种请求方式所对应的请求协议内容略有不同。有人会说GET是用于查询数据,POST是用于保存、更新数据,这么说有道理,但不够严谨。GET和POST只是一种传递数据的方式,GET也可以把数据传到服务器,他们的本质都是发送请求和接收结果,只是组织格式和数据量上面有差别,HTTP协议里面有介绍。
什么是GET请求?我们在浏览器地址栏上直接输入网址访问资源,这种请求方式是GET请求,超链接请求也属于GET请求。GET是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。而POST是通过HTTP post机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址,用户看不到这个过程。从数据传输量而言,GET设计成传输小数据,而且最好是不修改服务器的数据,所以浏览器一般都在地址栏里面可以看到,但POST一般都是用来传递大数据,或比较隐私的数据,所以在地址栏看不到,能不能看到不是协议规定的,是浏览器规定的。
GET和POST传输数据的数据量到底有多大限制呢?GET传送的数据量较小,不能大于2KB,POST传送的数据量较大,一般被默认为不受限制,但理论上,IIS4中最大量为80KB,IIS5中为100KB。POST基本没有限制,大家都上传过文件,都是用POST方式的,只不过要修改form里面的type参数。
从安全级别而言,GET安全性非常低,POST安全性较高。如果没有加密,他们安全级别都是一样的,随便一个监听器都可以把所有的数据监听到。GET是向服务器发索取数据的一种请求,而POST是向服务器提交数据的一种请求,在FORM表单中Method默认为GET,实质上,GET和POST只是发送机制不同,并不是一个取一个发。这就回到我们上面说的,简单的将POST和GET请求表述为一个查询数据,一个保存、更新数据这样是不严谨的。