文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么应用JavaEE的过滤器、监听、拦截技术

2023-06-02 12:26

关注

这篇文章主要讲解了“怎么应用JavaEE的过滤器、监听、拦截技术”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么应用JavaEE的过滤器、监听、拦截技术”吧!

一、Listener监听器

1、概念简介

JavaWeb三大组件:Servlet,Listener,Filter。监听器就是指在应用程序中监听相关对象状态变化的组件。

2、事件源对象

指被监听对象。

ServletContextListener生命周期监听,它有两个方法,出生时调用contextInitialized(),销毁时调用contextDestroyed();

ServletContextAttributeListener属性监听,它有三个方法,添加属性attributeAdded(),替换属性attributeReplaced(),移除属性时attributeRemoved()

HttpSessionListener生命周期监听:它有两个方法,出生时调用sessionCreated(),销毁时调用sessionDestroyed()

HttpSessioniAttributeListener属性监听:它有三个方法,添加属性attributeAdded(),替换属性attributeReplaced(),移除属性attributeRemoved()

ServletRequestListener生命周期监听:它有两个方法,出生时调用requestInitialized(),销毁时调用requestDestroyed()

ServletRequestAttributeListener属性监听:它有三个方法,添加属性attributeAdded(),替换属性attributeReplaced(),移除属性attributeRemoved()

3、编码案例

TheContextListener

public class TheContextListener implements ServletContextListener {    @Override    public void contextInitialized(ServletContextEvent servletContextEvent) {        System.out.println("初始化:TheContextListener");        ServletContext servletContext = servletContextEvent.getServletContext() ;        servletContext.setAttribute("author","cicada");    }    @Override    public void contextDestroyed(ServletContextEvent servletContextEvent) {        System.out.println("销毁:TheContextListener");    }}

TheRequestListener

public class TheRequestListener implements ServletRequestListener {    @Override    public void requestDestroyed(ServletRequestEvent servletRequestEvent) {        System.out.println("初始化:TheRequestListener");    }    @Override    public void requestInitialized(ServletRequestEvent servletRequestEvent) {        System.out.println("销毁:TheRequestListener");    }}

TheSessionListener

public class TheSessionListener implements HttpSessionListener {    @Override    public void sessionCreated(HttpSessionEvent httpSessionEvent) {        System.out.println("初始化:TheSessionListener");    }    @Override    public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {        System.out.println("销毁:TheSessionListener");    }}

RequestAttributeListener

public class RequestAttributeListener implements ServletRequestAttributeListener {    @Override    public void attributeAdded(ServletRequestAttributeEvent evt) {        System.out.println("Request添加属性:"+evt.getName()+";"+evt.getValue());    }    @Override    public void attributeRemoved(ServletRequestAttributeEvent evt) {        System.out.println("Request移除属性:"+evt.getName()+";"+evt.getValue());    }    @Override    public void attributeReplaced(ServletRequestAttributeEvent evt) {        System.out.println("Request替换属性:"+evt.getName()+";"+evt.getValue());    }}
<!-- 监听器相关配置 --><listener>    <listener-class>com.node05.servlet.listener.TheContextListener</listener-class></listener><listener>    <listener-class>com.node05.servlet.listener.TheSessionListener</listener-class></listener><listener>    <listener-class>com.node05.servlet.listener.TheRequestListener</listener-class></listener><listener>    <listener-class>com.node05.servlet.listener.RequestAttributeListener</listener-class></listener><session-config>    <!-- 设置session失效时间为1分钟 -->    <session-timeout>1</session-timeout></session-config>
public class ListenerServletImpl extends HttpServlet {    @Override    protected void doGet(HttpServletRequest request, HttpServletResponse response)            throws ServletException, IOException {        response.setContentType("text/html;charset=utf-8");        // 1、获取TheContextListener初始化数据        ServletContext servletContext = this.getServletContext() ;        String author = String.valueOf(servletContext.getAttribute("author")) ;        System.out.println("TheContextListener Author:"+author);        // 2、Request属性设置        request.setAttribute("mood","smile");        request.setAttribute("mood","agitated");        // 3、Session创建,1分钟失效,调用销毁        HttpSession session = request.getSession(true) ;        session.setAttribute("casually","casually");        response.getWriter().print("Hello:Listener");    }}

二、Filter过滤器

1、过滤器简介

客户端请求Servlet时,先执行相关Filter,如果Filter通过,则继承执行请求的Servlet;如果Filter不通过,则不会执行用户请求的Servlet。过滤器可以动态地拦截请求和响应。

2、Filter接口

Filter接口定义了三个核心方法。

应用程序启动时,服务器实例化Filter对象,并调用其init方法,读取web.xml配置,完成对象的初始化加载。

实际的过滤操作,请求达到服务器时,Servlet容器将先调用过滤器的doFilter方法。

容器在销毁过滤器前调用该方法,释放过滤器占用的资源。

3、编码案例

public class ThePrintLogFilter implements Filter {    @Override    public void init(FilterConfig filterConfig) throws ServletException {        String myName = filterConfig.getInitParameter("myName") ;        System.out.println("myName:"+myName);    }    @Override    public void doFilter(ServletRequest servletRequest,                         ServletResponse servletResponse,                         FilterChain chain) throws IOException, ServletException {        HttpServletRequest request = (HttpServletRequest)servletRequest ;        HttpServletResponse response = (HttpServletResponse)servletResponse ;        String name = request.getParameter("name") ;        if (!name.equals("cicada")){            response.getWriter().print("User Error !");            return ;        }        chain.doFilter(servletRequest,servletResponse);    }    @Override    public void destroy() {        System.out.println("ThePrintLogFilter destroy()");    }}
<!-- 过滤器相关配置 --><filter>    <filter-name>thePrintLogFilter</filter-name>    <filter-class>com.node05.servlet.filter.ThePrintLogFilter</filter-class>    <init-param>        <param-name>myName</param-name>        <param-value>cicada</param-value>    </init-param></filter><filter-mapping>    <filter-name>thePrintLogFilter</filter-name>    <url-pattern>/filterServletImpl</url-pattern></filter-mapping>
public class FilterServletImpl extends HttpServlet {    @Override    protected void doGet(HttpServletRequest request, HttpServletResponse response)            throws ServletException, IOException {        response.setContentType("text/html;charset=utf-8");        response.getWriter().print("Hello:Filter");    }}

三、Interceptor拦截器

Spring框架中的拦截器Interceptor类似于Servlet中的过滤器Filter,主要用于拦截用户请求并作相应的处理。例如通过拦截器可以进行权限验证、记录请求信息的日志、判断用户是否登录等。请求转发不执行拦截、过滤;重定向执行拦截和过滤。

感谢各位的阅读,以上就是“怎么应用JavaEE的过滤器、监听、拦截技术”的内容了,经过本文的学习后,相信大家对怎么应用JavaEE的过滤器、监听、拦截技术这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯