请求转发与请求重定向

forward和redirect对比

  •  从地址栏显示来说 forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器.浏览器根本不知道服务器发送的内容从哪里来的,所以它的地址栏还是原来的地址. redirect是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址.所以地址栏显示的是新的URL.
  •  从数据共享来说 forward:转发页面和转发到的页面可以共享request里面的数据. redirect:不能共享数据.
  •  从运用地方来说 forward:一般用于用户登陆的时候,根据角色转发到相应的模块. redirect:一般用于用户注销登陆时返回主页面和跳转到其它的网站等.
  • 从效率来说 forward:高. redirect:低. 本质区别

 

转发过程:客户浏览器发送http请求----》web服务器接受此请求--》调用内部的一个方法在容器内部完成请求处理和转发动作----》将目标资源 发送给客户;在这里,转发的路径必须是同一个web容器下的url,其不能转向到其他的web路径上去,中间传递的是自己的容器内的request。在客 户浏览器路径栏显示的仍然是其第一次访问的路径,也就是说客户是感觉不到服务器做了转发的。转发行为是浏览器只做了一次访问请求。

重定向过程:客户浏览器发送http请求----》web服务器接受后发送302状态码响应及对应新的location给客户浏览器--》客户浏览器发现 是302响应,则自动再发送一个新的http请求,请求url是新的location地址----》服务器根据此请求寻找资源并发送给客户。在这里 location可以重定向到任意URL,既然是浏览器重新发出了请求,则就没有什么request传递的概念了。在客户浏览器路径栏显示的是其重定向的 路径,客户可以观察到地址的变化的。重定向行为是浏览器做了至少两次的访问请求的。

 

get和post对比

1.get方法

  • 适用于url和表单请求(表单默认请求是get)
  • 发出请求后url地址变化为:原来url地址+?+property=value+&+property=value  。。。。。,字母和数字直接显示,空格变化为+,中文或者其他字符将会被加密,由于浏览器或者是服务器对url参数的限制(而不是url本身或者http协议),url的总长度是有限制的
  • 由于上述url地址变化的存在,倒置get请求存在安全问题

2.post方法

  • 只适用于表单传值请求
  • 请求的数据保存在http包体中,url地址变为新的页面的url
posted @ 2017-03-11 15:05  unbelievableme  阅读(328)  评论(0编辑  收藏  举报