HTTP各种请求方法的的幂等性和安全性

幂等性和安全性是http请求方法的特性, 比如 get请求方法是具有安全性的

安全性(此次请求不会修改后台):

   仅指该方法的多次调用不会产生副作用,不涉及传统意义上的“安全”,这里的副作用是指资源状态。
即,安全的方法不会修改资源状态,尽管多次调用的返回值可能不一样(被其他非安全方法修改过)。

幂等性(多次请求一个url,返回值不变):

    是指该方法多次调用返回的效果(形式)一致,客户端可以重复调用并且期望同样的结果。
一次调用和多次调用产生的效果是一致的,都是对一个变量进行赋值。
方法名安全性幂等性请求方法的作用
get请求指定的页面信息,并返回实体主体
head只请求页面的首部
options允许客户端查看服务器的性能
delete×请求服务器删除指定的数据
put×从客户端向服务器传送的数据取代指定的文档的内容
post××请求服务器接受所指定的文档作为对所标识的URI的新的从属实体

head方法:

	head方法和get方法差不多 , 但是head方法只会获取response响应头的信息, 并不会获取response.body的信息
	拿django来说, 如果有head方法, 他会走head方法, 如果你没定义head方法, 他会走get方法

在这里插入图片描述
在这里插入图片描述
响应体是空的
在这里插入图片描述
响应头有信息
在这里插入图片描述

options方法:

options方法响应体是这样的:
在这里插入图片描述

django中并不会走你定义的视图函数,但是会把视图的注释给返回
在这里插入图片描述

request请求走完中间件,然后通过下面这个方法,获得的响应体
在这里插入图片描述
如何避免options请求

put和delete方法为什么是幂等的?

(幂等性和安全性是由RESTful API接口设计标准及规范提出的)

简单的说,HTTP 的 method 就是一个残缺不全的设计缺陷,而 RESTful 则非要想去合理使用这个 method。
实际上设计接口用 GET、POST 就足够了,GET 做幂等操作(查询类),POST 做非幂等的修改类。
但实际上你还会遇上条件复杂的组合查询不得不用 POST 来实现( GET 有参数长度限制),
这时 RESTful 会推荐你使用 POST,这是 RESTful 的妥协,也恰好证明了 HTTP 的缺陷。

不要纠结这种问题了,好的文档比什么都重要。。
摘自:  https://www.v2ex.com/t/373770

POST和GET谁更安全

get更安全

get比post安全? -->get对于服务器是安全的–> get是幂等的,post是非幂等的

post更安全

① GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。
② 浏览器有跨域访问的限制,如果是get的话,jsonp很容易突破跨域的限制。但是post跨域比较不容易。
参考资料:https://blog.csdn.net/qq_38610536/article/details/83584681
https://blog.csdn.net/qq_41635167/article/details/83720985

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GET请求是幂等的,而POST请求一般不是幂等的。 根据引用\[1\]中的解释,幂等性是指一个HTTP请求不会对数据或状态做修改,并且每次请求都会返回同样的结果。GET请求只是获取数据,不会对服务器端的数据或状态做任何修改,因此是幂等的。而POST请求一般用于增删改的操作,每次请求都可能对服务器端的数据或状态做修改,所以一般不是幂等的。 在电商应用中,为了确保数据的一致性和安全性,后端WebService需要做到幂等性,即相同的请求多次提交也不会对数据产生重复的影响。而对于POST请求,为了避免用户重复提交表单,服务器端在操作成功后应该进行302跳转到另外一个页面,这样即使用户刷新页面,也不会重复提交表单。这是引用\[2\]中提到的建议。 总结起来,GET请求是幂等的,而POST请求一般不是幂等的。在电商应用中,后端WebService需要做到幂等性,而服务器端在处理POST请求时应该采取措施避免重复提交表单。 #### 引用[.reference_title] - *1* *3* [HTTP报文 请求方式 get/post请求方式 区别 幂等性](https://blog.csdn.net/weixin_65402230/article/details/127300647)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [HTTP协议的补充(POST、GET请求方法幂等性)](https://blog.csdn.net/qq_33945246/article/details/104613726)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值