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方式传递
-------------------------------------------------------------------------------------html
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服务器
// 客户端的类型,客户端的软件环境post
Accept: text/html, */* // 客户端所能接收的数据类型spa
Accept-Language: zh-cn // 客户端的语言环境设计
Accept-Encoding: gzip // 客户端支持的数据压缩格式日志
===========htm
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 服务器端的错误
------------------------------------------------------------------------------------------