Servlet-注释


我们平时使用部署描述符(web.xml文件)将应用程序部署到Web服务器中。tomcat7以上版本、Servlet API 3.0引入了一个名为javax.servlet.annotation的新程序包。它提供了可用于对Servlet类进行注释的注释类型。如果使用批注,则不需要部署描述符(web.xml)。

注释可以替换Web部署描述符文件(web.xml)中的等效XML配置,例如servlet声明和servlet映射。Servlet容器将在部署时处理带注释的类。

@WebServlet

@WebServlet用于通过容器声明Servlet的配置。下表包含用于WebServlet批注的属性的列表。

属性用处
String nameServlet的名称
String[] valueURL格式数组
String[] urlPatterns过滤器的URL格式数组
Int loadOnStartup提供启动顺序提示
WebInitParam[] initParamsServlet的初始化参数数组
Boolean asyncSupported支持Servlet异步操作
String smallIconServlet的小图标(如果有)
String largeIconServlet的大图标(如果有)
String description该Servlet的描述(如果有)
String displayName该Servlet的显示名称(如果有)

注释的valueurlPattern属性中必须声明至少一个URL模式 ,但不能两者都声明。

下面的示例描述如何使用@WebServlet批注。这是一个简单的servlet,显示文本Hello Servlet。

package servlet;

import java.io.IOException; 
import java.io.PrintWriter; 
import javax.servlet.ServletException; 
import javax.servlet.annotation.WebServlet; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse;
//注释标记为Servlet,相当于在web.xml上标记了该servlet且url-pattern为 "/Simple"
@WebServlet(value = "/Simple") 
public class Simple extends HttpServlet {

   private static final long serialVersionUID = 1L; 

   protected void doGet(HttpServletRequest request, HttpServletResponse response)  
      throws ServletException, IOException { 
   
      response.setContentType("text/html");   
      PrintWriter out = response.getWriter();   
      out.print("<html><body>");   
      out.print("<h3>Hello Servlet</h3>");   
      out.print("</body></html>");         
   }   
}

@WebInitParam

@WebInitParam批注用于为Servlet或Filter指定初始化参数。在WebFilter或WebSevlet批注中使用它。下表包含用于WebInitParam批注的属性的列表。

属性用处
String name初始化参数的名称
String value初始化参数的值
String description初始化参数说明

以下示例描述了如何将@WeInitParam注释与@WebServlet注释一起使用。这是一个简单的servlet,显示文本Hello Servlet和字符串值Hello World!从init参数中获取。

package servlet;

import java.io.IOException; 
import java.io.PrintWriter; 
import javax.servlet.ServletException; 
import javax.servlet.annotation.WebInitParam; 
import javax.servlet.annotation.WebServlet; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse;

@WebServlet(value = "/Simple", initParams = { 
	//通过name存储value在初始化参数列表中
   @WebInitParam(name = "foo", value = "Hello "), 
   @WebInitParam(name = "bar", value = " World!") 
}) 
public class Simple extends HttpServlet {

   private static final long serialVersionUID = 1L; 

   protected void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {   
      
      response.setContentType("text/html");   
      PrintWriter out = response.getWriter();   
      out.print("<html><body>");   
      out.print("<h3>Hello Servlet</h3>");   
      //通过name获取初始化值
      out.println(getInitParameter("foo")); 
      out.println(getInitParameter("bar")); 
      out.print("</body></html>");         
   }   
}

在这里插入图片描述

@Webfilter

这是用于声明servlet过滤器的注释。容器在部署时对其进行处理,并将相应的过滤器应用于指定的URL模式,Servlet和调度程序类型。

所述@WebFilter注解定义在web应用中的过滤器。此注释在类中指定,并且包含有关要声明的过滤器的元数据。带注释的过滤器必须指定至少一个URL模式。下表列出了用于WebFilter批注的属性。

属性作用
String filterName过滤器名字
String[] urlPatterns提供过滤器适用的值或url格式数组
DispatcherType[] dispatcherTypes指定过滤器适用的调度程序(请求/响应)的类型
String[] servletNames提供一个servlet名称数组
String displayName过滤器名称
String description过滤器说明
WebInitParam[] initParams过滤器的初始化参数数组
Boolean asyncSupported过滤器支持的异步操作
String smallIcon过滤器的小图标(如果有)
String largeIcon过滤器的大图标(如果有)

下面的示例描述如何使用@WebFilter批注。它是一个简单的LogFilter,可在控制台上显示 Init-param test-param 的值和当前时间时间戳。这意味着,过滤器的工作方式就像请求和响应之间的接口层。在这里,我们将“/*”用于urlPattern。这意味着,此过滤器适用于所有servlet。

package servlet;

import java.io.IOException; 
import javax.servlet.annotation.WebFilter; 
import javax.servlet.annotation.WebInitParam; 
import javax.servlet.*; 
import java.util.*;  

//urlPatterns = {"/*"}相当于<filter-mapping><url-pattern>/*</url-pattern></filter-mapping>
@WebFilter(urlPatterns = {"/*"}, initParams = { 
		//添加初始值
   @WebInitParam(name = "test-param", value = "Initialization Paramter")}) 
public class LogFilter implements Filter {
   
   public void init(FilterConfig config) throws ServletException { 
      //获取初始化值
      String testParam = config.getInitParameter("test-param");
            
      //打印在控制台
      System.out.println("Test Param: " + testParam);  
   } 

   public void doFilter(ServletRequest request, ServletResponse response,
      FilterChain chain) throws IOException, ServletException { 
	  
      //获取当前时间
      System.out.println("Time " + new Date().toString());  
         
      //将请求传递回过滤链
      chain.doFilter(request,response); 
   }

   public void destroy( ) {
      /* 在删除过滤器实例之前调用
       通过Web容器进行服务*/ 
   } 
}

上一篇:Servlet-点击计数器

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值