Get、post请求的区别

前言

不论是get还是post方式,都是属于http协议,只是http的两种不同的传输方式,而http协议是基于TCP传输协议的,所以无论是get还是post,在传输层的意义上来说是完全一样的。使用哪一种方式,由技术指定,结合不同的情况择优选择

 

一、传参方式的区别

GET请求会将参数跟在URL后进行传递,POST请求则是作为HTTP消息的实体(放在request body中)内容发送给WEB服务器。

疑问:使用get方式是否可以将参数写在request body中,使用post是否可以将参数写在url中?

答案是可以的,但是不同的服务器处理的方式也是不同的,但有些服务器会忽略get服务中的requestbody数据,有而些服务器可以读出来,所以不一定能被接收到,所以正常情况下还是得尊重行为准则。

二、发送数据大小区别

GET的请求长度受限于浏览器和web服务器,如IE对URL长度的限制是2083字节(2K+35)。其他浏览器(如火狐、谷歌)对GET的请求的长度会比IE长,但是,还是有限制。

而POST发送数据受限于服务端设置,比GET长得多,PHP默认POST的最大长度为8M。

疑问:限制的原因?

控制数据运输成本以及服务器成本,限制2k大小其实也只是个不成文的规定,因为如果超过2K,服务器可能直接丢弃不处理,与http协议是没有关系的,具体可以使用postman模拟

三、安全性的区别

POST请求相对于GET请求来说,会安全一些,因为GET发送的数据可以从url中看出来,而浏览器本身会缓存GET方式的请求

比如登录的时候,如果用get请求方式,那么请求的地址就是http://127.0.0.1/login.php?username=用户名&password=密码,用户名和密码都体现在url中了,其他人就可以从浏览器的历史记录中读取到这些数据,这样,账户密码就被人知道了,会带来安全问题(也就是敏感信息泄漏),POST方式就不存在这个问题(不会出现在浏览器的历史记录中)

补充:安全是相对的,http传输属于明文传输,在传输过程的任何一个节点,都有可能被截获,因此就需要加上传输加密,如对称加密、非对称加密等安全加密方式传输~get还受限于浏览器URL的自动转码,对于有歧义的字符,URL会进行自动转码处理

四、性能上

1、get会将数据缓存起来,而post不会,所以,加载静态资源(如图片、js这类)都是用get请求,浏览器会缓存这些资源,第二次加载的时候,会快很多

2、post会别get慢一些(原因可以让他们自己去百度,不用讲,也没必要明白,原因如下:)

post在真正接收数据之前会先将请求头发送给服务器进行确认,然后才真正发送数据

post请求的过程:

(1)浏览器请求tcp连接(第一次握手)

(2)服务器答应进行tcp连接(第二次握手)

(3)浏览器确认,并发送post请求头(第三次握手,这个报文比较小,所以http会在此时进行第一次数据发送)

(4)服务器返回100 Continue响应

(5)浏览器发送数据

(6)服务器返回200 OK响应

get请求的过程:

(1)浏览器请求tcp连接(第一次握手)

(2)服务器答应进行tcp连接(第二次握手)

(3)浏览器确认,并发送get请求头和数据(第三次握手,这个报文比较小,所以http会在此时进行第一次数据发送)

(4)服务器返回200 OK响应

也就是说,目测get的总耗是post的2/3左右

疑问1:部分网站上说,Get请求会将header和data一次性传输到位,而Post是header和body分开发送,只有等Post发送成功后才发送body,,这个没有想明白,因为通过模拟post请求,发现没有中间没有返回过100,是否可以证明它也是一次性发送

疑问2:get的效率会比post高,在小型网站中是否可以使用get来替换post以达到提高性能?

四、设计用途的区别

get用来查询-不操作数据,参数量小

post用来插入、更新数据 -- 安全要求高,数据量大

比喻:get像轿车,能送货,能力有限;post像货车,有货箱(请求正文)。运输量大且安全性高

get、post的区别的更多相关文章

  1. c#与java的区别

    经常有人问这种问题,用了些时间java之后,发现这俩玩意除了一小部分壳子长的还有能稍微凑合上,基本上没什么相似之处,可以说也就是马甲层面上的相似吧,还是比较短的马甲... 一般C#多用于业务系统的开发 ...

  2. jquery和Js的区别和基础操作

    jqery的语法和js的语法一样,算是把js升级了一下,这两种语法可以一起使用,只不过是用jqery更加方便 一个页面想要使用jqery的话,先要引入一下jqery包,jqery包从网上下一个就可以, ...

  3. 【原】nodejs全局安装和本地安装的区别

    来微信支付有2年多了,从2年前的互联网模式转变为O2O模式,主要的场景是跟线下的商户去打交道,不像以往的互联网模式,有产品经理提需求,我们帮忙去解决问题. 转型后是这样的,团队成员更多需要去寻找业务的 ...

  4. 探究@property申明对象属性时copy与strong的区别

    一.问题来源 一直没有搞清楚NSString.NSArray.NSDictionary--属性描述关键字copy和strong的区别,看别人的项目中属性定义有的用copy,有的用strong.自己在开 ...

  5. X86和X86_64和X64有什么区别?

    x86是指intel的开发的一种32位指令集,从386开始时代开始的,一直沿用至今,是一种cisc指令集,所有intel早期的cpu,amd早期的cpu都支持这种指令集,ntel官方文档里面称为&qu ...

  6. Java中Comparable与Comparator的区别

    相同 Comparable和Comparator都是用来实现对象的比较.排序 要想对象比较.排序,都需要实现Comparable或Comparator接口 Comparable和Comparator都 ...

  7. MySQL中interactive_timeout和wait_timeout的区别

    在用mysql客户端对数据库进行操作时,打开终端窗口,如果一段时间没有操作,再次操作时,常常会报如下错误: ERROR (HY000): Lost connection to MySQL server ...

  8. 设置line-height:1.5和line-height:150%或者line-height:150px的区别

    直接正题: 看一下line-height可能的值: 其实可以分为两类: (1)不带单位的(如line-height:1.5),这种是推荐使用的: (2)带单位的(如line-heigth:30px/1 ...

  9. C#中Length和Count的区别(个人观点)

    这篇文章将会很短...短到比你的JJ还短,当然开玩笑了.网上有说过Length和count的区别,都是很含糊的,我没有发现有 文章说得比较透彻的,所以,虽然这篇文章很短,我还是希望能留在首页,听听大家 ...

  10. select、poll、epoll之间的区别总结

    select.poll.epoll之间的区别总结 05/05. 2014 select,poll,epoll都是IO多路复用的机制.I/O多路复用就通过一种机制,可以监视多个描述符,一旦某个描述符就绪 ...

随机推荐

  1. <转载>关系规范化之求最小函数依赖集(最小覆盖)

    原文链接http://blog.csdn.net/icurious/article/details/51240114 最小函数依赖集 一.等价和覆盖 定义:关系模式R<U,F>上的两个依赖 ...

  2. mysql优化——show processlist命令详解

    SHOW PROCESSLIST显示哪些线程正在运行 不在mysql提示符下使用时用mysql -uroot  -e 'Show  processlist'   或者   mysqladmin pro ...

  3. 【Android开发经验】android:windowSoftInputMode属性具体解释

    本文章来自CSDN博客:http://blog.csdn.net/zhaokaiqiang1992.转载请注明地址! 在前面的一篇文章中,简单的介绍了一下怎样实现软键盘不自己主动弹出,使用的方法是设置 ...

  4. Sybase·调用存储过程并返回结果

    最近项目要用Sybase数据库实现分页,第一次使用Sybase数据库,也是第一次使用他的存储过程.2个多小时才调用成功,在此记录: 项目架构:SSM 1.Sybase本身不支持分页操作,需要写存储过程 ...

  5. Ubuntu16.04配置Tomcat的80端口访问

    [问题描述] 在阿里云 ECS 服务器 Ubuntu16.04 下部署 Java Web 应用时,发现配置的 Tomcat 服务启动后 80 端口无法被监听. [问题原因] 出现该问题的主要原因是:非 ...

  6. Java_oracle超出打开游标的最大数的原因和解决方案

    第一步:核查Oracle数据库 的游标的最大数 处理超出打开游标的最大数异常(ORA-01000: maximum open cursors exceeded) ORA-01000_maximum_o ...

  7. Function types cannot have argument labels 错误解决方案

    今天在封装网络工具类的时候 报错了 经过分析发现是在Swift3.0 把闭包的入参的参数名去掉就好了 正确写法 completion: @escaping (Any?, Bool)->() 错误 ...

  8. bat命令行实现全盘遍历搜索文件

    背景:当想要查找一个文件时,记得放在某个盘里.手动去遍历时感觉好心累,找了半天还是没有找着(虽然win有自带的搜索框,但是看着进度条的速度,我便果断的点了取消).基于这个情况,所以写了脚本满足自身查找 ...

  9. Java并发编程-并发工具类及线程池

    JUC中提供了几个比较常用的并发工具类,比如CountDownLatch.CyclicBarrier.Semaphore. CountDownLatch: countdownlatch是一个同步工具类 ...

  10. LeetCode(102):二叉树的层次遍历

    Medium! 题目描述: 给定一个二叉树,返回其按层次遍历的节点值. (即逐层地,从左到右访问所有节点). 例如:给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 ...