`
bjlf1105
  • 浏览: 24782 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

关于Get和Post以及请求的进一步理解

阅读更多

GET与POST,是HTTP协议中的内容,表示客户端向服务器递交请求的方法,GET/POST…等方法在协议中的大概用意是
GET – 获取资源信息
POST – 提交信息
DELETE – 删除资源
HEAD – 响应中不要包含消息体
PUT –创建或修改资源
等等
99.99%的情况下,我们只跟GET/POST方法打交道,其它方法,可忽略,不用管它们
Web容器在接收到请求之后,会调用service()方法来处理各种请求,service()方法会根据HTTP HEAD中包含的方法定义(GET还是POST)来调用doGet()或doPost()或其它方法
一般情况下,建议不要直接覆盖service()方法,而是覆盖doGet()和doPost()方法即可!

 

          什么情况下,浏览器会发出GET请求?
你直接在浏览器地址栏输入URL地址,然后回车,访问网址的时候
页面上有一个<a href=“http://xx/xxx.xx”>xxx</a>链接,你点击这个链接访问的时候
页面上有一个表单(form),你明确定义了method=“GET”的时候
你通过javascript代码:window.location.href = “http://xxx.xxx.xx”来刷新当前页面的时候
除非你明确定义method=“POST”,否则总是会发出GET请求
          什么情况下,浏览器会发出POST请求?
页面上有一个表单(form),你明确定义了method=“POST”的时候
如何得知浏览器发出的是什么请求?
你可以用httplook这个工具,拦截所有的HTTP访问,查看其HTTP HEAD
你可以用firefox,下载它的一个插件:HttpFox

 

GET 请求通过在URL地址后面附加参数的形式来向后台递交数据
POST 请求则通过HTTP HEAD来递交数据(即不会出现在URL地址的后面)
由于GET是将参数附加在URL地址的后面,所以,它的长度可能会受到浏览器的限制(在HTTP协议中,没有参数长度上限的说法,如果参数长度受限,都是由于特定的浏览器或服务器导致的);POST请求的数据长度一般不会受限

 

通过表单向后台递交数据的过程中:在客户端,GET与POST的主要区别在于是否是通过URL地址来传参,GET使用起来很方便,但不适合大批数据的传输,POST则需要定义一个form元素才可以使用(稍微麻烦一点),所以大批数据提交请用POST要方便数据量少,请用GET
在服务器端呢?在服务器端,一般情况下无需关注是GET还是POST方法提交的数据!不管是GET还是POST,对于服务器端来说,其接收从客户端传递过来的参数的过程都是完全一样的 !后台通过request.getParameter()来处理get或者post请求向后台递交的参数。

 

浏览器什么时候,会向服务器发起请求:
 我们在浏览器地址栏输入网址,敲回车
 我们刷新页面
 我们用javascript去向后台发起请求
 覆盖window.location.href
 调用form对象的submit()方法
 浏览器解释到网页中包含URL地址的元素时
    link – CSS文件
    script – JS文件
    frame
    iframe
    img
    等等

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics