Servlet常见注解&Filter常见注解

作用: 用于将一个类声明为 Servlet
描述: 该注解将会在部署时被容器处理, 容器将根据具体的属性配置将相应的类部署为 Servlet.

属性名类型属性描述
nameString指定servlet的name属性,等价于<Servlet-name>.如果没有显示指定,则该servlet的取值即为类的全限定名.
valueString[]等价于urlPatterns,二者不能共存.
urlPatternsString[]指定一组servlet的url的匹配模式,等价于 <url-pattern> 标签.
loadOnStartupint指定servlet的加载顺序,等价于 <load-on-startup> 标签.
initParamsWebInitParam[]指定一组初始化参数,等价于 <init-param> 标签.
//注解配置  
@WebServlet(displayName = "UserServlet", // 描述
      name = "UserServlet", // servlet名称
      urlPatterns = { "/user" }, // url
      loadOnStartup = 1, // 启动项
      initParams = { @WebInitParam(name = "username", value = "张三") }) // 初始化参数
public class UserServlet extends HttpServlet {
    private String username;
    public UserServlet() {
        System.out.println("UserServlet...");
    }
    @Override
    public void init(ServletConfig config) throws ServletException {
        // 获取初始化信息:张三
        username = config.getInitParameter("username");
    }
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        // 主要内容操作
    }
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        // 主要内容操作
        System.out.println(username);
    }
}

Filter(过滤器)主要对请求到达前进行处理,也可以在请求结束后进行处理,类似于链式。
一个请求可以被多个过滤器拦截到,会依次进入各个Filter中,放行后直至进入Servlet,Servlet处理请求结束后,回到各个Filter继续执行后面的代码,先执行的Filter后执行完。
常用到的地方:
1.用户权限过滤
2.记录日志
3.字符编码处理

属性名类型属性描述
asyncSupportedboolean指定Filter是否支持异步模式
dispatcherTypesDispatcherType[]指定Filter对哪种方式的请求进行过滤. 支持的属性:ASYNC、ERROR、FORWARD、INCLUDE、REQUEST; 默认过滤所有方式的请求
filterNameStringFilter名称
initParamsWebInitParam[]配置参数
displayNameStringFilter显示名
servletNamesString[]指定对哪些Servlet进行过滤
urlPatterns/valueString[]两个属性作用相同,指定拦截的路径

用户权限过滤示例:
自定义过滤器,实现 javax.servlet.Filter 接口,通过注解方式配置。拦截所有的请求,放行登录页面、登录操作请求,其余请求需要在登录后才可访问。同时配置参数,指定要放行的路径和请求的字符集。

@WebFilter(filterName = "loginFilter", urlPatterns = "/*", initParams = {
        @WebInitParam(name = "loginUI", value = "/home/loginUI"),
        @WebInitParam(name = "loginProcess", value = "home/login"),
        @WebInitParam(name = "encoding", value = "utf-8") })
public class LoginFilter implements Filter {
    private FilterConfig config;
    @Override
    public void init(FilterConfig config) throws ServletException {
        this.config = config;
    }
    @Override
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
            throws IOException, ServletException {
        // 获取配置参数
        String loginUI = config.getInitParameter("loginUI");
        String loginProcess = config.getInitParameter("loginProcess");
        String encoding = config.getInitParameter("encoding");
        HttpServletRequest request = (HttpServletRequest) req;
        HttpServletResponse response = (HttpServletResponse) res;
         // 设置请求的字符集(post请求方式有效)
        request.setCharacterEncoding(encoding);
        // 不带http://域名:端口的地址
        String uri = request.getRequestURI();
        if (uri.contains(loginUI) || uri.contains(loginProcess)) {
            // 请求的登录,放行
            chain.doFilter(request, response);
        } else {
            if (request.getSession().getAttribute("user") == null) {
                // 重定向到登录页面
                response.sendRedirect(request.getContextPath() + loginUI);
            } else {
                // 已经登录,放行
                chain.doFilter(request, response);
            }
        }
    }
 
    @Override
    public void destroy() {
        this.config = null;
    }
}

@WebListener注解
该注解用于将类声明为监听器,被 @WebListener 标注的类必须实现以下至少一个接口:
1.ServletContextListener
2.ServletContextAttributeListener
3.ServletRequestListener
4.ServletRequestAttributeListener
5.HttpSessionListener
6.HttpSessionAttributeListener

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值