1.GET方法:获取资源
GET方法用来请求访问已被URL识别的资源。指定的资源经服务器端接续后返回内容。也就是说,如果请求的资源是文本,那就保持原样返回;如果像是CGI(Conmmon Gateway Interface,通用网关接口)那样的程序,则返回执行后的输出结果;
GET方法请求响应的例子:
请求:GET/index.html HTTP/1.1
Host:www.hackr.jp
响应:返回index.html的页面资源
请求:GET/index.html HTTP/1.1
Host:www.hackr.jp
if-Modified-Since:The,12,Jul 2012 07:30:00 GMT
响应:仅返回2012年12日7点30分以后更新过的index.html页面资源。如果未有内容更新,则以状态码304Not Modidied作为响应返回
2.POST:传输实体主体
POST方法用来传输实体的主体
虽然用GET方法也可以进行传输实体的主体,但一般不用GET方法进行传输,而是用POST方法,虽说POST的功能与GET很相似,但是POST的主要目的并不是获取相应的主体内容。
POST方法请求响应的例子:
请求:GET/index.html HTTP/1.1
Host:www.hackr.jp
Content-Length:1560(1560字节的数据)
3.GET方法和POST方法的区别
GET | POST | |
后退按钮/刷新 | 无害 | 数据会被重新提交(浏览器应该告知用户数据会被重新提交) |
书签 | 可收藏为书签 | 不可收藏为书签 |
缓存 | 能被缓存 | 不能缓存 |
编码格式 | 只能进行url编码 | 有多种编码方式 |
历史 | 参数保留在浏览器中 | 参数不会保留在浏览器中 |
对数据类型的限制 | 只允许ASCII字符 | 没有限制,也允许二进制数据 |
安全性 | 与post相比,GET的安全性较差,因为所发送的数据是URL的一部分,在发送密码或者其他敏感信息时绝不要用GET | POST比GET更安全,因为参数不会被保存在浏览器历史或web服务器日志中 |
可见性 | 在数据在URL中对所有人都是可见的 | 数据不会显示在URL中 |
对数据长度的限制 | 有限制,当发送数据时,GET方法向URL添加数据:URL的长度是受限制的(YRL的最大长度是2048个字符) | 无限制 |
数据包 | GET产生一个TCP数据包,浏览器把请求头和请求数据一并发过去,服务器响应200(返回数据) | POST产生两个TCP数据包,浏览器会将请求头发送给服务器,待服务器响应100后,浏览器再发送请求数据,服务器响应200(返回数据) |