浅谈servlet

------one--------

Filter过滤器

  作用:Filter解决的是多个Servlet中所存在的公有代码的冗余问题,引入Filter之后,把多个Servlet的冗余代码,提取到Filter中,那样用户的请求就会先经过Filter,然后再访问后续的Servlet。既能保证用户功能的完成,同时也解决了代码的冗余问题。

  1、开发步骤

    a、implements Filter  实现Filter接口

复制代码
public class MyFilger implements Filter{
    
    @Override
    public void doFilter(ServletRequest request,ServletResponse response,FilterChain chain){
        System.out.println("--------MyFilter invoke before request-------");
        chain.doFilter(request,response);
        System.out.println("--------MyFilter invoke after response--------");
    }
}
复制代码

    Filter不仅可以拦截request,还可以拦截reponse。在doFilter()方法中有一个参数为FilterChain对象,FilterChain.doFilter(request,response)方法意味着将request传递给后续的Servlet,所以,在该方法之间的代码会在request之前执行,而Servlet所相应的response,也会在执行完Filter中的该方法之后的代码后才响应回client。

    b、在web.xml中配置Filter

复制代码
<servlet>
    <servlet-name>targetServlet</servlet-name>
    <servlet-class>com.liquidxu.servlet.TargetServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>targetServlet</servlet-name>
    <url-pattern>/target</url-pattern>
</servlet-mapping>

<filter>
    <filter-name>myFilter</filter-name>
    <filter-class>com.liquid.filter.MyFilter</filter-class>
</filter>
<filter-mappine>
    <filter-name>myFilter</filter-name>
    <url-pattern>target</url-pattern>
</filter-mapping>
复制代码

    filter的写法跟servlet的写法基本一致,但是需要注意的是,servlet的url-pattern是该servlet的访问路径,而filter想拦截哪个servlet,就将自己的url-pattern写的跟该servlet的url-pattern一致即可。

    如果该filter想拦截所有的请求,该filter的url-pattern写成/*即可。

    如果该filter想批量拦截对Servlet的请求,则需要修改Servlet的url-pattern。例如,Servlet1的url-pattern为/admin/targer1,Servlet2的url-pattern为/admin/target2,这样将该filter的url-pattern写成/admin/*,这样就可以同时过滤到Servlet1和Servlet2了。

  2、存在的问题

    Filter默认只过滤用户的直接请求或者redirect的请求,而不过滤forward跳转。

    解决方案:

      

<filter-mapping>
    <filter-name>myFilter</filter-name>
    <url-pattern>target</url-pattern>
    <dispatcher>REQUEST</dispatcher>
    <dispatcher>FORWARD</dispatcher>
</filter-mapping>

    只需在filter-mapping节点下加入此内容即可。

 

 

 

 

------two-------

Servlet内容拾遗

  1、Servlet的创建

    Servlet对象为一种类型只创建一个对象提供服务,所以Serlvet对象为单例。

    多个线程访问同一个Servlet对象,Servlet是没有成员变量的,因此可以保证线程安全。

  2、Servlet的生命周期

    a、默认用户第一次访问的时候会创建Servlet。

    b、Tomcat启动的时候Servlet也可能会被创建,不过需要配置web.xml文件如下:

<servlet>
    <serlvet-name>targetServlet</servlet-name>
    <servlet-class>com.liquidxu.servlet.TargetServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
   注意: <load-on-startup>1</load-on-startup>意思是:

贴一段英文原汁原味的解释如下:
Servlet specification:
The load-on-startup element indicates that this servlet should be loaded (instantiated and have its init() called) on the startup of the web application. The optional contents of these element must be an integer indicating the order in which the servlet should be loaded. If the value is a negative integer, or the element is not present, the container is free to load the servlet whenever it chooses.   If the value is a positive integer or 0, the container must load and initialize the servlet as the application is deployed. The container must guarantee that servlets marked with lower integers are loaded before servlets marked with higher integers. The container may choose the order of loading of servlets with the same load-on-start-up value.

翻译过来的意思大致如下:
1)load-on-startup元素标记容器是否在启动的时候就加载这个servlet(实例化并调用其init()方法)。

2)它的值必须是一个整数,表示servlet应该被载入的顺序

2)当值为0或者大于0时,表示容器在应用启动时就加载并初始化这个servlet;

3)当为负数或没有值时,可以由server容器自行决定何时load该servlet. 句中的it应该指的是container而不是servlet.

4)正数的值越小,该servlet的优先级越高,应用启动时就越先加载。

5)当值相同时,容器就会自己选择顺序来加载。

所以,<load-on-startup>x</load-on-startup>,中x的取值1,2,3,4,5代表的是优先级,而非启动延迟时间。

如下题目:

2.web.xml中不包括哪些定义(多选)

 

a.默认起始页

 

b.servlet启动延迟时间定义

 

c.error处理页面

 

d.jsp文件改动后重新载入时间

 

答案:b,d

通常大多数Servlet是在用户第一次请求的时候由应用服务器创建并初始化,但<load-on-startup>n</load-on-startup>   可以用来改变这种状况,根据自己需要改变加载的优先级!

 

 

    c、Servlet创建以后,会调用一次init方法,完成初始化处理。

    d、Servlet的service方法对外提供服务,每一次请求都会调用。

    e、Servlet会在销毁之前调用destory方法。

  3、Servlet规范组件的启动顺序

    ServletContextListener----->Filter----->Servlet

  4、Servlet的核心实现原理

    用户请求该Servlet的时候,tomcat通过用户请求的url-pattern通过查找web.xml文件中的内容,获得该url-pattern所对应的Servlet的全限定名。然后利用该Servlet类的全限定名便可以通过反射创建出该Servlet类的对象,之后便调用该Servlet类的service方法来进行服务。

 

posted @ 2017-06-23 15:11  ctgu_czy  阅读(174)  评论(0编辑  收藏  举报