HTTP-8种请求类型

八种请求类型的介绍

GET请求
从服务器取回数据。只是取回数据,并不会产生其他影响。例如用GET请求访问/employee/101/张三,可以取回该员工的详细资料。
请注意,查询字符串(名称/值对)是在 GET 请求的 URL 中发送的:

/test/demo_form.asp?name1=value1&name2=value2

POST请求
创建一个实体,也就是一个没有ID的资源。一旦这个请求成功执行了,就会在HTTP请求的响应中返回这个新创建的实体的ID。我们通常用POST请求来上传文件或者表单。例如用POST请求访问/employee/102/李四,将会创建一个ID为102的新员工。

查询字符串(名称/值对)是在 POST 请求的 HTTP 消息主体中发送的:

POST /test/demo_form.asp HTTP/1.1
Host: w3schools.com
name1=value1&name2=value2

PUT请求
用来更新一个已有的实体。通过把已经存在的资源的ID和新的实体用PUT请求上传到服务器来更新资源。例如用PUT请求访问/employee/101/王五,可以更新员工101的信息
DELETE请求
从服务器上删除资源。需要把要删除的资源的ID上传给服务器例如用DELETE请求访问/employee/101/王五,可以删除员工101的信息
TRACE请求
提供一种方法来测试当一个请求发生的时候,服务器通过网络收到的内容。所以它会返回你发送的内容。
HEAD请求
HEAD请求和GET请求资源类似,但仅仅返回相应的头部,没有具体的响应体。它也不会对服务器造成其他影响
OPTIONS请求
OPTIONS允许客户端请求一个服务所支持的请求方法。它所对应的响应头是Allow,它非常简洁地列出了支持的方法。下面为服务端成功处理了OPTIONS请求后,响应的内容:Allow: HEAD,GET,PUT,DELETE,OPTIONS
CONNECT请求
主要用来建立一个对资源的网络连接。一旦建立连接后,会响应一个200状态码和一条"Connectioin Established"的消息。

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协议中预留给能够将连接改为管道方式的代理服务器。

详解GET请求和POST请求的区别

GET - 从指定的资源请求数据。
POST - 向指定的资源提交要被处理的数据

原理区别
一般我们在浏览器输入一个网址访问网站都是GET请求。在HTTP的请求类型中,GET和HEAD是幂等的,被称为安全方法。因为使用GET和HEAD请求不会在服务器上产生任何结果,但安全的方法并不是什么动作都不产生,这里说的安全方法仅仅是指不会修改信息。根据HTTP规范,POST请求可能会修改服务器上的资源。比如在掘金用户提交一篇文章或者读者提交评论就是通过POST实现的,因为提交后的资源(即某个页面)不同了,或者说资源被修改了,这便是"不安全方法"。
表现形式区别
GET请求请求的数据会附加在URL之后,以’?'分割URL和传输数据,多个参数用&连接。URL的编码格式采用的是ASCII编码,而非unicode,所有的非ASCII字符都要编码之后在传输。POST请求会把请求的数据放在HTTP请求包的包体中。因此,GET请求的数据会暴露在地址栏中,而POST请求则不会。
传输数据的大小
在HTTP规范中,对于地址栏的长度和传输数据的大小没有进行限制,但是实际开发过程中,特定的浏览器和服务器会对URL的长度有限制。因此,使用GET请求时,传输数据会受到URL长度的限制。对于POST请求理论上是不会受限,但是实际上各个服务器会规定对POST提交数据大小进行限制。
安全性
POST的安全性高于GET的安全性。这里所说的安全性并不是上面提到的安全方法。而是GET请求会把信息都暴露在地址栏。此时信息可能通过浏览器缓存以及历史纪录的原因泄露。而POST请求则不存在这个问题。此外GET请求提交的数据还可能造成Cross-site request frogery攻击,即利用网站对用户标识的信任欺骗用户的浏览器发送HTTP请求给目标站点。

  • 2
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值