总结:WEB组件的三种关联关系

 

WEB应用程序最突出的优点是能够聚合大量的信息资源。单个Web组件所提供的信息和功能是有限的,因此需要通过Web组件间的关联来实现信息资源和功能的聚合。

 

1、请求转发

 

    允许把客户端的请求转发给同一个应用程序的其他组件。使用RequestDispatcher.forward() 函数来转发收到的HTTP请求,并将来自客户端的最初请求的ServletReauest和ServletResponse对象传递给转发目标组件。目标组件执行具体的请求处理操作,并生成响应结果。转发目标组件会将处理结果生成应答,返回给客户端。

请求转发方式通常用于Web应用层的Servlet控制器。在JSP中可以通过标签来实现转发。请求转发的方式只能把请求转发给同一Web应用中的组件。

同时,请求转发的源组件和目标组件共享request范围内的共享数据。


   两个组件间共享一个Request对象,只能转发到同一应用中的Web对象。
   
        

   例如在Servlet中
   RequestDispatcher rd=request.getRequestDispatcher("hello.jsp");
   rd.forward(request,response);
   或在JSP中使用标签<jsp:forward page="hello.jsp">

 

请求转发的方式其实就是以一种以链接来聚合页面资源的方法,这种链接可以有任意多个。


2、请求重定向

  

    与请求转发类似,都是将客户端的请求转发传递给其他Web组件进行处理。

主要区别如下:
   
2.1 Web组件可以将请求重定向到任何一个URL上,而不仅仅是同一Web应用中的URL

2.2 重定向的源组件和目标组件之间不共用一个Request对象,因此不能共享Request的资源

2.3重定向是返回一个应答给客户端,然后再重新发送一个请求给目标URL,所以地址栏内会有显示,而转发是直接把这个请求转发给另一个URL,地址栏没有显示

        

   在Servlet中
   response.sendRedirect("http://www.126.com");

 

可以从当前页面转向任意URL,无法使用前面的Request对象,适于转到外部网站页面。


3、包含


   组件通过include包含另一个组件,可以避免同一功能反复出现在多个页面中。
  
           
   Servlet的Service函数中:
   RequestDispatcher rd=request.getRequestDispatcher("header.jsp");
   rd.include(request,response);
   JSP中使用标签:<%@include file="header.jsp"%>

 

-------------------------------------------------------------------------------------------------------->>>>>>>>>>>>>>---------------

 

由于response是jsp页面中的隐含对象,故在jsp页面中可以用response.sendRedirect()直接实现重定位。

  注意:

  (1).使用response.sendRedirect时,前面不能有HTML输出。



  这并不是绝对的,不能有HTML输出其实是指不能有HTML被送到了浏览器。事实上现在的server都有cache机制,一般在8K(我是说JSP SERVER),这就意味着,除非你关闭了cache,或者你使用了out.flush()强制刷新,那么在使用sendRedirect之前,有少量的HTML输出也是允许的。

  (2).response.sendRedirect之后,应该紧跟一句return;

  我们已经知道response.sendRedirect是通过浏览器来做转向的,所以只有在页面处理完成后,才会有实际的动作。既然你已经要做转向了,那么后的输出还有什么意义呢?而且有可能会因为后面的输出导致转向失败。

  补充

  1.RequestDispatcher.forward()

  是在服务器端起作用,当使用forward()时,Servlet engine传递HTTP请求从当前的Servlet or JSP到另外一个Servlet,JSP 或普通HTML文件,也即你的form提交至a.jsp,在a.jsp用到了forward()重定向至b.jsp,此时form提交的所有信息在b.jsp都可以获得,参数自动传递.

  但forward()无法重定向至有frame的jsp文件,可以重定向至有frame的html文件,同时forward()无法在后面带参数传递,比如servlet?name=frank,这样不行,可以程序内通过response.setAttribute("name",name)来传至下一个页面.

  重定向后浏览器地址栏URL不变.

  例:在servlet中进行重定向

public void doPost(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException
{
 response.setContentType("text/html; charset=gb2312");
 ServletContext sc = getServletContext();
 RequestDispatcher rd = null;
 rd = sc.getRequestDispatcher("/index.jsp"); //定向的页面
 rd.forward(request, response);
}

  通常在servlet中使用,不在jsp中使用。

  2.response.sendRedirect()

  是在用户的浏览器端工作,sendRedirect()可以带参数传递,比如servlet?name=frank传至下个页面,同时它可以重定向至不同的主机上,sendRedirect()可以重定向有frame.的jsp文件.

  重定向后在浏览器地址栏上会出现重定向页面的URL

  例:在servlet中重定向

public void doPost(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException
{
 response.setContentType("text/html; charset=gb2312");
 response.sendRedirect("/index.jsp");
}

  由于response是jsp页面中的隐含对象,故在jsp页面中可以用response.sendRedirect()直接实现重定位。

  注意:

  (1).使用response.sendRedirect时,前面不能有HTML输出

  这并不是绝对的,不能有HTML输出其实是指不能有HTML被送到了浏览器。事实上现在的server都有cache机制,一般在8K(我是说JSP SERVER),这就意味着,除非你关闭了cache,或者你使用了out.flush()强制刷新,那么在使用sendRedirect之前,有少量的HTML输出也是允许的。

  (2).response.sendRedirect之后,应该紧跟一句return;

  我们已经知道response.sendRedirect是通过浏览器来做转向的,所以只有在页面处理完成后,才会有实际的动作。既然你已经要做转向了,那么后的输出还有什么意义呢?而且有可能会因为后面的输出导致转向失败。

  比较:

  (1).Request Dispatcher.forward()是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;

  (2).response.sendRedirect()则是完全的跳转,浏览器将会得到跳转的地址,并重新发送请求链接。这样,从浏览器的地址栏中可以看到跳转后的链接地址。

  前者更加高效,在前者可以满足需要时,尽量使用RequestDispatcher.forward()方法.

  注:在有些情况下,比如,需要跳转到一个其它服务器上的资源,则必须使用HttpServletResponse.sendRequest()方法。

  3.<jsp:forward page="" />

  它的底层部分是由RequestDispatcher来实现的,因此它带有RequestDispatcher.forward()方法的印记。

  如果在<jsp:forward>之前有很多输出,前面的输出已使缓冲区满,将自动输出到客户端,那么该语句将不起作用,这一点应该特别注意。

  另外要注意:它不能改变浏览器地址,刷新的话会导致重复提交

  4.修改HTTP header的Location属性来重定向

  通过设置直接修改地址栏来实现页面的重定向。

  jsp文件代码如下:

<%
response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);
String newLocn = "/newpath/jsa.jsp";
response.setHeader("Location",newLocn);
%>

  5.JSP中实现在某页面停留若干秒后,自动重定向到另一页面

  在html文件中,下面的代码:

<meta http-equiv="refresh" content="300; url=target.jsp">

  它的含义:在5分钟之后正在浏览的页面将会自动变为target.html这一页。代码中300为刷新的延迟时间,以秒为单位。targer.html为你想转向的目标页,若为本页则为自动刷新本页。

  由上可知,可以通过setHeader来实现某页面停留若干秒后,自动重定向到另一页面。

  关键代码:

String content=stayTime+";URL="+URL;
response.setHeader("REFRESH",content);

不要仅仅为了把变量传到下一个页面而使用session作用域,那会无故增大变量的作用域,转发也许可以帮助你解决这个问题。
重定向:以前的request中存放的变量全部失效,并进入一个新的request作用域。
转发:以前的request中存放的变量不会失效,就像把两个页面拼到了一起。

--------------------------------------------------------------------------------->>>>>>>>>>>>>>>>>>>>>>>>>>>>--------------

1HttpServletResponse接口中的sendRedirect方法

       sendRedirect方法通常被称为“响应重定向”,

 

如果用响应对象调用了该方法,本质上就是浏览器对服务器重新提交了

 

请求。比如LoginDemo应用中,如果使用该方法跳转, 那么写法是:

 

       response.sendRedirect(“normal/loginSuccessful.jsp”);

 

       response.sendRedirect(“error/loginFail.jsp”);

 

或者是:

 

       response.sendRedirect(“/LoginDemo/normal/loginSuccessful.jsp”);

 

       response.sendRedirect(“/LoginDemo/normal/loginFail.jsp”);

 

      

       这两种写法的主要区别在于跳转页面路径的写法,第一种写法的路径

 

没有用“/”开始,而第二种写法的路径使用了”/”开始。我们需要理解是

 

否使用”/”有什么不同?

 

n  如果不使用”/”开头,代表是请求路径。是相对于当前的请求路径而

 

言。

 

n  如果使用”/”开头,代表相对于容器根路径,即”/”表示容器的根路

 

径,因此”/”后面使用的是应用上下文的名字”LoginDemo”

 

2RequestDispatcher接口中的forward方法

除了上文提到的响应重定向,RequestDispatcher(通常称为“请求转发

 

器”)接口中提供的forward方法是另一个最常使用的跳转方法,此方

 

法通常被称为“请求转发”。请求转发的本质是容器直接将当前请求

 

提交给另一个资源,客户端一无所知,并不重新提交请求。与响应重

 

定向不同的是,要调用forward方法,首先必须获得RequestDispatcher

 

口的对象。而响应对象由于容器会自动生成并传递给doXXX方法,可

 

以直接使用。而获得RequestDispatcher类型的对象,可以通过两个接口

 

获得,即

 

ServletRequest中的getRequestDispatcher方法以及ServletContext中的

 

getRequestDispatchergetNamedDispatcher方法。接下来分别讨论两种

 

接口中获得请求转发器的方法。

 

 

结合LoginDemo应用实例,如果使用该方法跳转(仅以成功页面为例)

 

方式如下:

 

RequestDispatcher dis1=request.getRequestDispatcher

 

(“normal/loginSuccessful.jsp”);

 

dis1.forward(request,response);

 

或者:

 

RequestDispatcher dis1=request.getRequestDispatcher

 

(“/normal/loginSuccessful.jsp”);

 

dis1.forward(request,response);

 

          这两种写法的主要区别在于转发路径的写法,第一种写法的路径没有用“/

 

开始,而第二种写法的路径使用了”/”开始。我们需要理解是否使用”/”有什么不

 

同?

n  如果不使用”/”开头,代表是请求路径。是相对于当前的请求路径而言。

 

n  如果使用”/”开头,代表相对于当前上下文路径,即”/”表示应用上下

 

”/LoginDemo”的根。

 

建议开发人员选择跳转方式时,首先考虑是否需要将当前请求对象转发,如

果需要,选择使用请求转发,否则即可使用响应重定向,其次考虑使用哪种

路径书写方式。在实际开发中,使用ServletRequest接口获得请求转发器,从

而进行请求转发的方式居多,Struts框架的跳转方式默认也是此种方式。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值