客户端向服务器发送一次HTTP请求,该请求可能会经过多个信息资源处理以后才把结果返回给客户端,各个信息资源使用请求转发机制相互转发请求。根据转发方式的不同,可以区分为直接请求转发(Forward)和间接请求转发(Redirect)。
直接请求转发(Forward)
直接转发方式用的更多,一般说的请求转发指的就是直接转发方式。javax.serlvet.RequestDispatcher接口是请求转发器必须实现的接口,由Web容器为Servlet提供实现该接口的对象,通过调用该接口的forward方法达到请求转发的目的,示例代码如下:
1 // Servlet里处理get请求的方法 2 public void doGet(HTTPServletRequest request, HTTPServletResponse response){ 3 // 获取请求转发器对象,该转发器的指向通过getRequestDisPatcher()的参数设置 4 RequestDispatcher requestDispatcher = request.getRequestDispatcher("资源的URL"); 5 // 调用forward()方法,转发请求 6 requestDispatcher.forward(request,response); 7 }
图1 转发示意图
转发过程:客户浏览器发送HTTP请求->Web服务器接受此请求->调用内部的一个方法在容器内部完成请求处理和转发动作->将目标资源发送给客户。转发的路径是同一个Web容器下的URL,不能转向到其他的Web容器路径上,中间传递的是自己容器内的request对象。在客户端浏览器路径栏显示的仍然是第一次访问的路径,也就是说客户是感觉不到服务器做了转发的。对于转发,浏览器只发送了一次HTTP请求。
间接请求转发(Redirect)
间接转发方式也称为重定向,用于防止用户的非正常访问。例如,用户在没有登录的情况下访问后台资源,Servlet可以通过该HTTP请求重定向到登录页面,让用户登录以后再访问。在Servlet中,通过调用HTTPServletRequest类的response对象的sendRedirect方法,告诉客户端重定向到指定的URL,示例代码如下:
1 // Servlet中处理get请求的方法 2 public void doGet(HTTPServletRequest request,HTTPServletResponse response){ 3 // 请求重定向到另外的资源 4 response.sendRedirect("资源的URL"); 5 }
图2 重定向示意图
重定向过程:客户端发送HTTP请求->服务器接收后发送302状态码响应以及对应新的location给客户端->客户端发现是302响应,自动发送一个新的HTTP请求,请求URL是新的location->服务器根据此请求寻找资源并发送给客户端。location可以重定向到任意URL,因为客户端重新发送了请求,所以没有传递request对象。在浏览器路径栏显示的是重定向的 路径,用户可以观察到地址的变化。对于重定向,客户端发送了2次请求,对应两个request对象。
转发是服务器行为,重定向是客户端行为。从数据共享来说,转发页面和转发到的页面可以共享同一个request和response对象里面的数据,需要防止表单重复提交,重定向则不能。从用途来说,转发用于用户登录后根据角色转发到相应的模块,重定向用于用户退出后跳转到登录页面。从效率上来说,转发更高,因为它只发送一次请求。
生活中的例子
假设某个人去办理执照,
转发:先去了A局,A局看了以后,知道这个事情由B局管,让你坐一会儿,自己到后面办公室联系了B的人,让他们办好后,送了过来;重定向:先去了A局,A局的人说:“这个事情不归我们管,去B局”,然后,从A退了出来,自己乘车去了B局。
参考资料
《Java程序员面试笔试宝典》 P172
原文地址:https://www.cnblogs.com/WJQ2017/p/8176360.html