GET & POST
GET
1.GET 的本质是"得"
2.从服务器拿数据,效率更高
3.从数学的角度来讲,GET 的结果是"幂等"的
4.GET请求能够被缓存
5.在 HTTP 协议定义中,没有对GET请求的数据大小限制,不过因为浏览器不同,一般限制在 2~8K 之间
6.所有的参数包装在URL中,并且服务器的访问日志会记录,不要传递敏感信息
参数格式? 在资源路径末尾添加?表示追加参数 变量名=变量值 每一个变量及值按照"变量名=变量值"方式设定,不能包含空格或者中文 等特殊符号
& 多个参数使用&连接
POST
1.POST 的本质是"给"
2.向服务器发送数据,也可以获得服务器处理之后的结果,效率不如GET
3.POST请求不能被缓存,post再次提交数据,页面会有提示:是否发送数据.....
POST提交数据比较大,大小靠服务器的设定值限制,PHP通常限定 2M
URL中,只有资源路径,但不包含参数,服务器日志不会记录参数,相对更安全
参数被包装成二进制的数据体,格式与GET基本一致,只是不包含?
所有设计用户隐私的数据(密码,银行卡号)一定记住使用POST方式传递
-------------------------------------------------------------------------------------
HTTP通信过程 - 请求
GET /MJServer/resources/images/1.jpg HTTP/1.1
Host: 192.168.1.105:8080 // 客户端想访问的服务器主机地址
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.9) Firefox/30.0
// 客户端的类型,客户端的软件环境
Accept: text/html, */* // 客户端所能接收的数据类型
Accept-Language: zh-cn // 客户端的语言环境
Accept-Encoding: gzip // 客户端支持的数据压缩格式
===========
HTTP通信过程 - 响应
HTTP/1.1 200 OK
Server: Apache-Coyote/1.1 // 服务器的类型
Content-Type: image/jpeg // 返回数据的类型
Content-Length: 56811 // 返回数据的长度
Date: Mon, 23 Jun 2014 12:54:52 GMT // 响应的时间
------------------------------------------------------------------------------------------
200(状态码) OK
2xx成功
4xx 客户端的错误
5xx 服务器端的错误
------------------------------------------------------------------------------------------