JavaWeb-过滤器,监听器的实现流程

过滤器

Filter:过滤器 ,用来过滤网站的数据;

  • 处理中文乱码
  • 登录验证….

在这里插入图片描述

1.导包:过滤器要到的包是 javax.servlet
2.编写过滤器:实现Filter接口,重写对应的方法即可

public class CharacterEncodingFilter implements Filter {

    //初始化:web服务器启动,就以及初始化了,随时等待过滤对象出现!
    public void init(FilterConfig filterConfig) throws ServletException {
        System.out.println("CharacterEncodingFilter初始化");
    }

    //Chain : 链
    /*
    1. 过滤中的所有代码,在过滤特定请求的时候都会执行
    2. 必须要让过滤器继续同行
        chain.doFilter(request,response);
     */
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        request.setCharacterEncoding("utf-8");
        response.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=UTF-8");

        System.out.println("CharacterEncodingFilter执行前....");
        chain.doFilter(request,response); //让我们的请求继续走,如果不写,程序到这里就被拦截停止!
        System.out.println("CharacterEncodingFilter执行后....");
    }

    //销毁:web服务器关闭的时候,过滤会销毁
    public void destroy() {
        System.out.println("CharacterEncodingFilter销毁");
    }
}

3.在web.xml中配置Filter

<filter>
    <filter-name>CharacterEncodingFilter</filter-name>
    <filter-class>com.yang.servlet.CharacterEncodingFilter</filter-class>
</filter>

<filter-mapping>
    <filter-name>CharacterEncodingFilter</filter-name>
    <!--只要是 /servlet的任何请求,会经过这个过滤器-->
    <url-pattern>/zifu</url-pattern>
</filter-mapping>

监听器

实现监听器的接口

public class OnlineCountListener implements HttpSessionListener {

    //创建session监听: 看你的一举一动
    //一旦创建Session就会触发一次这个事件!
    public void sessionCreated(HttpSessionEvent se) {
        ServletContext ctx = se.getSession().getServletContext();

        System.out.println(se.getSession().getId());

        Integer onlineCount = (Integer) ctx.getAttribute("OnlineCount");

        if (onlineCount==null){
            onlineCount = new Integer(1);
        }else {
            int count = onlineCount.intValue();
            onlineCount = new Integer(count+1);
        }

        ctx.setAttribute("OnlineCount",onlineCount);

    }

    //销毁session监听
    //一旦销毁Session就会触发一次这个事件!
    public void sessionDestroyed(HttpSessionEvent se) {
        ServletContext ctx = se.getSession().getServletContext();

        Integer onlineCount = (Integer) ctx.getAttribute("OnlineCount");

        if (onlineCount==null){
            onlineCount = new Integer(0);
        }else {
            int count = onlineCount.intValue();
            onlineCount = new Integer(count-1);
        }

        ctx.setAttribute("OnlineCount",onlineCount);

    }
}

编写测试,用index.jsp即可

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>登录</title>
</head>
<body>

<h1>当前:<span><%=this.getServletConfig().getServletContext().getAttribute("OnlineCount")%>人在使用</span></h1>

</html>

在web.xml注册监听器

<!--注册监听器-->
<listener>
    <listener-class>com.yang.servlet.OnlineCountListener</listener-class>
</listener>

应用

public class TestPanel {
    public static void main(String[] args) {
        Frame frame = new Frame("中秋节快乐");  //新建一个窗体
        Panel panel = new Panel(null); //面板
        frame.setLayout(null); //设置窗体的布局

        frame.setBounds(300, 300, 500, 500);
        frame.setBackground(new Color(0, 0, 255)); //设置背景颜色

        panel.setBounds(50, 50, 300, 300);
        panel.setBackground(new Color(0, 255, 0)); //设置背景颜色

        frame.add(panel);

        frame.setVisible(true);

        //监听事件,监听关闭事件
        frame.addWindowListener(new WindowAdapter() {
            @Override
            public void windowClosing(WindowEvent e) {
               System.exit(0);
            }
        });
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的示例代码,用于演示如何在Java Web项目中使用过滤器监听器来完成用户权限验证功能。请注意,这只是一个演示代码,具体实现方式可能因项目需求和环境而异。 1. 首先,创建一个Java Web项目,并添加一个过滤器(Filter)用于验证用户权限: ``` public class AuthFilter implements Filter { public void init(FilterConfig config) throws ServletException { // 初始化操作 } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // 验证用户权限 HttpServletRequest req = (HttpServletRequest) request; HttpServletResponse res = (HttpServletResponse) response; HttpSession session = req.getSession(false); if (session == null || session.getAttribute("user") == null) { // 用户未登录,跳转到登录页面 res.sendRedirect(req.getContextPath() + "/login.jsp"); return; } // 用户已登录,继续处理请求 chain.doFilter(request, response); } public void destroy() { // 销毁操作 } } ``` 2. 接下来,创建一个监听器(Listener),用于记录用户登录和退出的日志: ``` public class LoginLogoutListener implements HttpSessionListener { public void sessionCreated(HttpSessionEvent event) { // 新建session HttpSession session = event.getSession(); System.out.println("Session created: " + session.getId()); } public void sessionDestroyed(HttpSessionEvent event) { // 销毁session HttpSession session = event.getSession(); System.out.println("Session destroyed: " + session.getId()); } } ``` 3. 在Web.xml文件中配置过滤器监听器: ``` <filter> <filter-name>AuthFilter</filter-name> <filter-class>com.example.AuthFilter</filter-class> </filter> <filter-mapping> <filter-name>AuthFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <listener> <listener-class>com.example.LoginLogoutListener</listener-class> </listener> ``` 4. 最后,在需要进行用户权限验证的Servlet或JSP页面中添加以下代码段: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> <c:if test="${sessionScope.user != null}"> <!-- 用户已登录,继续处理请求 --> </c:if> ``` 以上是一个简单的示例代码,用于演示如何在Java Web项目中使用过滤器监听器来完成用户权限验证功能。具体实现方式可能因项目需求和环境而异,您可以根据具体情况进行修改和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值