19.03.14JavaWeb作业

1.Annotation

what/introduction

java.lang.annotation,接口 Annotation。对于Annotation,是Java5的新特性,JDK5引入了Metadata(元数据)很容易的就能够调用Annotations。Annotations提供一些本来不属于程序的数据,比如:一段代码的作者或者告诉编译器禁止一些特殊的错误。An annotation 对代码的执行没有什么影响。Annotations使用@annotation的形式应用于代码:类(class),属性(attribute),方法(method)等等。一个Annotation出现在上面提到的开始位置,而且一般只有一行,也可以包含有任意的参数。

Annotation的架构图:

从中,我们可以看出:

(01) 1个Annotation 和 1个RetentionPolicy关联。
       可以理解为:每1个Annotation对象,都会有唯一的RetentionPolicy属性。

(02) 1个Annotation 和 1~n个ElementType关联。
       可以理解为:对于每1个Annotation对象,可以有若干个ElementType属性。

(03) Annotation 有许多实现类,包括:Deprecated, Documented, Inherited, Override等等。
       Annotation 的每一个实现类,都“和1个RetentionPolicy关联”并且“和1~n个ElementType关联”。

examples

public class AnnotationDemo {
//@Test注解修饰方法A
@Test
public static void A(){
System.out.println("Test.....");
}

//一个方法上可以拥有多个不同的注解
@Deprecated
@SuppressWarnings("uncheck")
public static void B(){

}
}

//声明Test注解 @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface Test { }

public enum ElementType {
/**标明该注解可以用于类、接口(包括注解类型)或enum声明*/
TYPE,

/** 标明该注解可以用于字段(域)声明,包括enum实例 */
FIELD,

/** 标明该注解可以用于方法声明 */
METHOD,

/** 标明该注解可以用于参数声明 */
PARAMETER,

/** 标明注解可以用于构造函数声明 */
CONSTRUCTOR,

/** 标明注解可以用于局部变量声明 */
LOCAL_VARIABLE,

/** 标明注解可以用于注解声明(应用于另一个注解上)*/
ANNOTATION_TYPE,

/** 标明注解可以用于包声明 */
PACKAGE,

/**
* 标明注解可以用于类型参数声明(1.8新加入)
* @since 1.8
*/
TYPE_PARAMETER,

/**
* 类型使用声明(1.8新加入)
* @since 1.8
*/
TYPE_USE
}
2.deployment description

context-param、listener、filter、servlet

 首先可以肯定的是,加载顺序与它们在 web.xml 配置文件中的先后顺序无关。即不会因为 filter 写在 listener 的前面而会先加载 filter。最终得出的结论是: listener -> filter -> servlet

    同时还存在着这样一种配置节:context-param,它用于向 ServletContext 提供键值对,即应用程序上下文的初始化参数。我们的 listener, filter 等在初始化时会用到这些上下文中的信息,那么 context-param 配置节是不是应该写在 listener 配置节前呢?实际上 context-param 配置节可写在任意位置。但是,真正的加载顺序为:context-param -> listener -> filter -> servlet 

    对于某一类配置节点的多个配置项来说,则与它们出现的顺序是有关的。以 filter 为例,web.xml 中当然可以定义多个 filter,与 filter 相关的一个配置节点是 filter-mapping,这里一定要注意,对于拥有相同 filter-name 的 filter 和 filter-mapping 配置节而言,filter-mapping 必须出现在 filter 之后,否则当解析到 filter-mapping 时,它所对应的 filter-name 还未定义。web 容器启动时初始化每个 filter 时,是按照 filter 配置节出现的顺序来初始化的,当请求资源匹配多个 filter-mapping 时, filter 拦截资源是按照 filter-mapping 配置节出现的顺序来依次调用 doFilter() 方法的。

    servlet 同 filter 类似 ,此处不再赘述。

   由此,可以看出,web.xml 的加载顺序是: context-param -> listener -> filter -> servlet ,而同个类型之间的实际程序调用的时候的顺序是根据对应的 mapping 的顺序进行调用的

context-param

配置的是整个web应用的上下文初始化参数。
技术分享 技术分享
    <context>
        <param-name></param-name>
        <param-value></param-value>
    </context>
技术分享 技术分享

如果想要获得参数值,可以在servlet中调用: 
(1) getServletContext.getInitParameter(“”); 
(2) getServletConfig().getServletContext().getInitParameter(); 
在web应用部署完成以后,值没法改变。

listener

<listener>

<listener-class></listener-class>

</listener>

web容器自己会根据listener-class中的类implements什么类型的接口进行判断。
技术分享 技术分享

filter

 <filter>
     <filter-name></filer-name>
     <filer-class></filer-class>
     <init-param>
         <param-name></param-name>
         <param-value></param-value>
     </init-param>
 </filter>

<filer-mapping>
    <filer-name></filer-name>
    <url-pattern></url-pattern>
</filer-mapping>
技术分享 技术分享
  • filer 有两个配置节点:filer和filer-mapping,其中对应的filer-mapping必须在filer配置节点配置完成后才能进行配置。而filer-mapping的映射可以根据:url-pattern,类似于servlet-mapping。或者直接使用。

servlet

 <servlet>
     <servlet-name></servlet-name>
     <servlet-class></servlet-class>
     <init-param>
         <param-name></param-name>
         <param-value></param-value>
     </init-param>
     <init-param>
         <param-name></param-name>
         <param-value></param-value>
     </init-param>
     <load-on-startup></load-on-startup>
 </servlet>

<servlet-mapping>
    <servlet-name></servlet-name>
    <url-pattern></url-pattern>
</servlet-mapping>
技术分享 技术分享
  •  init-param:配置的key/value会被设置到该servlet对应的servletConfig对象。注意:不同于ServletContxt,每个servlet 

都会有自己的servletConfig。部署完成后,参数值不能变。 
??load-on-startup:用来确定servlet的加载时间。如果未设置或者为负数,则在该servlet对应的第一个用户请求到来时,才加载servlet类,并调用init()。如果为正数或者0,则在web应用部署后就加载servlet。其数字的大小又标识了加载的顺序,值越小越早被加载,如果值相等,就先在web.xml声明的先加载。

session-config (会话超时设置,单位分钟)

 <session-config>
     <session-timeout></session-timeout>
 </session-config>
技术分享 技术分享
  • 如果某个会话在一定时间内未被访问,服务器可以抛弃它以节省内存。 可通过使用HttpSession的setMaxInactiveInterval方法明确设置单个会话对象的超时值(此时单位是秒),或者可利用session-config元素制定缺省超时值(此时单位是分支)。

猜你喜欢

转载自www.cnblogs.com/avopen/p/10549811.html