web.xml里<filter-mapping>中的<dispatcher&a

时间:2021-01-23 17:51:38

https://my.oschina.net/bianxin/blog/2876640

 

2.4版本的servlet规范在部属描述符中新增加了一个<dispatcher>元素,这个元素有四个可能的值:即REQUEST,FORWARD,INCLUDE和ERROR,可以在一个<filter-mapping>元素中加入任意数目的<dispatcher>,使得filter将会作用于直接从客户端过来的request,通过forward过来的request,通过include过来的request和通过<error-page>过来的request。如果没有指定任何< dispatcher >元素,默认值是REQUEST。可以通过下面几个例子来辅助理解。 
例1:

Xml代码  
  1. <filter-mapping>   
  2. <filter-name>Logging Filter</filter-name>   
  3. <url-pattern>/products/*</url-pattern>   
  4. </filter-mapping>  

 

这种情况下,过滤器将会作用于直接从客户端发过来的以/products/…开始的请求。因为这里没有制定任何的< dispatcher >元素,默认值是REQUEST。 

例2:

Xml代码  
  1. <filter-mapping>   
  2. <filter-name>Logging Filter</filter-name>   
  3. <servlet-name>ProductServlet</servlet-name>   
  4. <dispatcher>INCLUDE</dispatcher>   
  5. </filter-mapping>   

这种情况下,如果请求是通过request dispatcher的include方法传递过来的对ProductServlet的请求,则要经过这个过滤器的过滤。其它的诸如从客户端直接过来的对ProductServlet的请求等都不需要经过这个过滤器。 
指定filter的匹配方式有两种方法:直接指定url-pattern和指定servlet,后者相当于把指定的servlet对应的url-pattern作为filter的匹配模式 
filter的路径匹配和servlet是一样的,都遵循servlet规范中《SRV.11.2 Specification of Mappings》一节的说明 

例3:

Xml代码  
  1. <filter-mapping>   
  2. <filter-name>Logging Filter</filter-name>   
  3. <url-pattern>/products/*</url-pattern>   
  4. <dispatcher>FORWARD</dispatcher>   
  5. <dispatcher>REQUEST</dispatcher>   
  6. </filter-mapping>   

 

在这种情况下,如果请求是以/products/…开头的,并且是通过request dispatcher的forward方法传递过来或者直接从客户端传递过来的,则必须经过这个过滤器。
参考资料:http://topic.csdn.net/t/20060322/23/4633313.html

 

——————————————————————————————————————————————

 

都表示要跳转到其他资源,不同的是,如果使用forward跳转则后面的response输出则不会执行,而用include
来跳转,则include的servlet执行完后,再返回到原来的servlet执行response的输出(如果有)。如:
servlet A
RequestDispatcher disp = request.getRequestDispatcher("B");
disp.forward(request, response);
System.out.println("servlet A completed");
PrintWriter pw = response.getWriter();
pw.println("servlet A");

servlet B
PrintWriter pw = response.getWriter();
pw.println("servlet B");

输出结果:
控制台:servlet A completed
页面:servlet B
如果将forward换成include的话,则结果为:
控制台:servlet A completed
页面:servlet B servlet A
PS:如果在servlet B里吧pw给close掉了的话,那servlet A 这里就无法输出了,则结果就和第一个一样。

——————————————————————————————————————————————

https://www.cnblogs.com/mfmdaoyou/p/7085031.html

參见 文库/java/javaEE全新学习教程2.2节 

1.通过URL调用

2通过提交表单

3超链接

4 javascript写一个函数,调用这个函数

 

1,首先在project的WebRoot目录下建立一个java类。这个类继承了HttpServlet  ,是一个servlet

 

package make.servlet;

import java.io.*;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.*;


public class HelloServlet extends HttpServlet {
  protected void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException
  {
 String url=request.getRequestURI().toString();
 System.out.println(url);
 
 PrintWriter out=response.getWriter();
 out.println("hello servlet");
  }
}

 

然后,把这个servlet映射到web.xml文件里

 

<servlet>
  <servlet-name>hello</servlet-name>
  <servlet-class>make.servlet.HelloServlet</servlet-class>
</servlet>

<servlet-mapping>
 <servlet-name>hello</servlet-name>
 <url-pattern>/hello</url-pattern>        //一定要有斜杠,这样就能够通过/hello来调用刚才的servlet类
</servlet-mapping>

 

这样,就能够在地址栏中输入http://localhost:8080/myservlet/hello       注意myservlet是project名字,hello是url映射的名字

 

2,另外一种,通过表单

自己在webRoot目录下新建一个htmL文件

 <body>
   <form action="/myservlet/hello">
     <input type="submit"  value="test">    
   </form>

当点击testbutton的时候,就能够显示刚才的页面

3超链接

在刚才的html文件里。插入一个超链接  

   <a href="/myservlet/hello">Link---</a>

当点击这个超链接的时候,也会显示刚才的页面

4

通过脚本语言写一个函数

在刚刚的html文件里。增加

 

<script type="text/javascript">
function test()
{
  var f=document.forms[0];
  f.action="/myservlet/hello";
  f.submit();
}

 

然后。再添加一个button。当点击这个button的时候,就调用这个函数,函数的功能就是转到servlet页面

 <input type="button"  value="button" onclick="test();">    当然,这个按钮要放到表单里面