网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
一般我们在浏览器输入一个网址访问网站都是GET
请求;再FORM
表单中,可以通过设置Method
指定提交方式为GET
或者POST
提交方式,默认为GET提交方式。
HTTP定义了与服务器交互的不同方法,其中最基本的四种:GET,POST,PUT,DELETE,HEAD,其中GET
和HEAD
被称为安全方法
,因为使用GET和HEAD的HTTP请求不会产生什么动作。不会产生动作意味着GET和HEAD的HTTP请求不会在服务器上产生任何结果。但是安全方法并不是什么动作都不产生,这里的安全方法仅仅指不会修改信息。
根据HTTP规范,POS
T可能会修改
服务器上的资源
的请求。比如CSDN的博客,用户提交一篇文章或者一个读者提交评论是通过POST请求来实现的,因为再提交文章或者评论提交后资源(即某个页面)不同了,或者说资源被修改了,这些便是“不安全方法”
。
两者对比
方法 | GET | POST |
---|---|---|
GET在浏览器回退时是无害的 | POST会再次提交请求 | |
GET产生的URL地址可以被Bookmark | POST不可以。 | |
GET请求会被浏览器主动cache | POST不会,除非手动设置。 | |
GET请求只能进行url编码,而POST支持多种编码方式。 | ||
GET请求参数会被完整保留在浏览器历史记录里 | POST中的参数不会被保留。 | |
GET请求在URL中传送的参数是有长度限制的 | POST么有。 | |
对参数的数据类型,GET只接受ASCII字符 | 而POST没有限制。 | |
GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。 | ||
GET参数通过URL传 | POST放在Request body中。 |
注意重点
GET和POST还有一个重大区别:
简单的说:GET产生一个TCP数据包;POST产生两个TCP数据包。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**