zoukankan      html  css  js  c++  java
  • GET和POST的比较

    一、GET和POST长度的限制问题

    GET

    1.GET是通过URL提交数据,因此GET可提交的数据量就跟URL所能达到的最大长度有直接关系。
    2.实际上HTTP协议对URL长度是没有限制的;限制URL长度大多数是浏览器或者服务器的配置参数

    POST

    1.同样的,HTTP协议没有对POST进行任何限制,一般是受服务器配置限制或者内存大小。
    2.PHP下可以修改php.conf的postmaxsize来设置POST的大小。请求header的content-length问题如果有人恶意伪造content-length很大的包头,但实际上发送content-length很小的请求,这样服务器会一直干等,直到超时。当然服务器是可以通过设置来避免该问题的

    二、GET和POST的安全性

    1.GET是通过URL方式请求,可以直接看到,明文传输。
    2.POST是通过请求header请求,可以开发者工具或者抓包可以看到,同样也是明文的。
    3.GET请求会保存在浏览器历史纪录中,还可能会保存在Web的日志中。GET和POST对服务器的状态根据http的设计,大家在看到get的时候,都期望这个请求对服务器没有修改,看到post的时候,都认为这对服务器产生了修改。

    三、GET幂等,POST不幂等

    幂等是指同一个请求方法执行多次和仅执行一次的效果完全相同。

    1.按照RFC规范,PUT,DELETE和安全方法都是幂等的。虽说是规范,但服务端实现是否幂等是无法确保的。
    2.引入幂等主要是为了处理同一个请求重复发送的情况,比如在请求响应前失去连接,如果方法是幂等的,就可以放心地重发一次请求。这也是浏览器在后退/刷新时遇到POST会给用户提示的原因:POST语义不是幂等的,重复请求可能会带来意想不到的后果。
    3.比如在微博这个场景里,GET的语义会被用在「看看我的Timeline上最新的20条微博」这样的场景,而POST的语义会被用在「发微博、评论、点赞」这样的场景中。

    参考链接:

    1、https://www.zhihu.com/question/28586791

  • 相关阅读:
    对象进行比较
    java中length,length(),size()区别
    引用数据类型、自定义类
    java方法
    学员信息管理系统案例
    商品库存管理查看增减
    引用数据类型Scanner,Random
    Cantor表巧妙的做法
    UVA 11292 The dragon of Loowater勇士斗恶龙 11729 突击战 Commando War
    期末,祝不挂
  • 原文地址:https://www.cnblogs.com/yanmuxiao/p/8732556.html
Copyright © 2011-2022 走看看