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

来源:互联网 发布:我知你好未再妈妈网 编辑:程序博客网 时间:2024/06/01 11:44

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


    博客分类: 
  • JavaWeb
浏览器JavaScriptFirefoxCSSWeb

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 
    等等

原创粉丝点击