【Javaweb】过滤器和监听器的常见应用

这篇博客介绍了Java GUI中使用监听器的示例,特别是针对窗口关闭事件的处理。同时,展示了用户登录和注销的实现,通过在Session中存储用户信息来控制主页的访问权限。并讨论了如何使用过滤器进行权限验证,确保只有登录用户可以访问特定页面。
摘要由CSDN通过智能技术生成

1.监听器:在GUI中经常使用

package com.hxl.listener;

import java.awt.*;
import java.awt.event.WindowEvent;
import java.awt.event.WindowListener;

public class TestPanel {
    public static void main(String[] args) {
        Frame frame = new Frame("2021中秋节快乐");//新建一个窗体
        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 WindowListener() {
            public void windowOpened(WindowEvent e) {
                System.out.println("打开");
            }

            public void windowClosing(WindowEvent e) {
                System.out.println("关闭ing");
                System.exit(0);
            }

            public void windowClosed(WindowEvent e) {
                System.out.println("关闭ed");
            }

            public void windowIconified(WindowEvent e) {
                
            }

            public void windowDeiconified(WindowEvent e) {

            }

            public void windowActivated(WindowEvent e) {
                System.out.println("激活");
            }

            public void windowDeactivated(WindowEvent e) {
                System.out.println("未激活");
            }
        });
    }
}

在这里插入图片描述

2.用户登录后才能进入主页,用户注销后就不能进入首页

  • 用户登录之后,向Session中放入用户的数据

  • 进入主页的时候要判断用户是否登录,要求在过滤器中实现

    • 首先我们先进入登录页面

      <%@ page contentType="text/html;charset=UTF-8" language="java" %>
      <html>
      <head>
          <title>登录</title>
      </head>
      <body>
      
      <form action="/servlet/login" method="post">
          <input type="text" name="username">
          <input type="submit">
      </form>
      
      </body>
      </html>
      
    • 进入登录页面后我们走一个请求

      package com.hxl.servlet;
      
      import javax.servlet.ServletException;
      import javax.servlet.http.HttpServlet;
      import javax.servlet.http.HttpServletRequest;
      import javax.servlet.http.HttpServletResponse;
      import java.io.IOException;
      
      public class LoginServlet extends HttpServlet {
          @Override
          protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
              //获取前端请求的参数
              String username = req.getParameter("username");
              if(username.equals("admin")){
                  //登录成功,存了一个session
                  req.getSession().setAttribute("Constant.USER_SESSION", req.getSession().getId());
                  resp.sendRedirect("/sys/success.jsp");
              }else{
                  //登录失败
                  resp.sendRedirect("/sys/error.jsp");
              }
          }
      
          @Override
          protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
              doGet(req, resp);
          }
      }
      
    • 成功走成功的页面

      <%@ page contentType="text/html;charset=UTF-8" language="java" %>
      <html>
      <head>
          <title>主页</title>
      </head>
      <body>
      
      <%--
      //没有下面的代码,就算没有admin也可以进入成功页面。这是jsp做的一种方法。我们一般不用
      <%
          Object user_session = request.getSession().getAttribute("USER_SESSION");
          if(user_session==null){
              response.sendRedirect("/Login.jsp");
          }
      %>
      --%>
      
      
      <h3>成功了</h3>
      <p><a href="/servlet/logout">注销</a> </p>
      </body>
      </html>
      
    • 失败走失败的页面

      <%@ page contentType="text/html;charset=UTF-8" language="java" %>
      <html>
      <head>
          <title>错误</title>
      </head>
      <body>
      <h3>用户名写错了</h3>
      <p><a href="/Login.jsp">返回到登录页面</a> </p>
      </body>
      </html>
      
    • 我们再加个权限验证过滤器

      package com.hxl.servlet;
      
      import javax.servlet.ServletException;
      import javax.servlet.http.HttpServlet;
      import javax.servlet.http.HttpServletRequest;
      import javax.servlet.http.HttpServletResponse;
      import java.io.IOException;
      
      public class LoginServlet extends HttpServlet {
          @Override
          protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
              //获取前端请求的参数
              String username = req.getParameter("username");
              if(username.equals("admin")){
                  //登录成功,存了一个session
                  req.getSession().setAttribute("Constant.USER_SESSION", req.getSession().getId());
                  resp.sendRedirect("/sys/success.jsp");
              }else{
                  //登录失败
                  resp.sendRedirect("/sys/error.jsp");
              }
          }
      
          @Override
          protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
              doGet(req, resp);
          }
      }
      
    • 我们发现session的一个名字比较常用,所以我们将他变成常量

      package com.hxl.util;
      
      public class Constant {
          public final static String USER_SESSION = "USER_SESSION";
      }
      
    • 每一个servlet、Filter都需要在xml中进行配置

      <servlet>
          <servlet-name>LoginServlet</servlet-name>
          <servlet-class>com.hxl.servlet.LoginServlet</servlet-class>
      </servlet>
      <servlet-mapping>
          <servlet-name>LoginServlet</servlet-name>
          <url-pattern>/servlet/login</url-pattern>
      </servlet-mapping>
      <servlet>
          <servlet-name>LoginOutServlet</servlet-name>
          <servlet-class>com.hxl.servlet.LoginOutServlet</servlet-class>
      </servlet>
      <servlet-mapping>
          <servlet-name>LoginOutServlet</servlet-name>
          <url-pattern>/servlet/logout</url-pattern>
      </servlet-mapping>
      <filter>
          <filter-name>SysFilter</filter-name>
          <filter-class>com.hxl.filter.SysFilter</filter-class>
      </filter>
      <filter-mapping>
          <filter-name>SysFilter</filter-name>
          <url-pattern>/sys/*</url-pattern>
      </filter-mapping>
      

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秦 羽

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值