HTTP定义了与服务器不同的交互方法,其中最基本的五种:GET,POST,DELETE,HEAD,PUT
其中GET和HEAD被成为安全方法,因为使用GET和HEAD请求不会产生什么动作,也就意味着这两个请求动作不会在服务器上产生任何结果,这个安全动作并不是指不会做任何动作,而是指不会修改信息
它们的底层其实都是基于TCP完成的,只不过HTTP协议给他们贴上了不同的标签,但其实底层实现都是一样的
GET和POST的流程区别
GET
第一次握手:浏览器请求服务器建立连接
第二次握手:服务器确认浏览器请求连接,并发出连接请求
第三次握手:浏览器确认,并发送GET请求报文
服务器返回200响应报文
POST
第一次握手:浏览器请求服务器建立连接
第二次握手:服务器确认浏览器请求连接,并发出连接请求
第三次握手:浏览器确认,并发送POST请求报文
服务器返回100响应报文
浏览器发送数据
服务器返回200 OK响应
总结一下GET和POST的区别
- post更安全,因为get请求的数据都在url中,而且浏览器会将get请求缓存起来,而post则不会被缓存、保存在浏览器日志以及浏览器浏览记录中
- post发送的数据更大一些,虽然HTTP对url长度没有限制,但是不同的浏览器对其有不同的规定,一般不超过2K
- post能发送更多的数据类型,get只能发送ASCII码
- post比get更慢一点,究其原因是因为post要产生两次数据报文
- post用于修改和写入数据,get一般用于读取数据或请求数据