用户权限过滤器

本文详细介绍了如何在web应用中实现用户登录后的权限管理,包括区分管理员与普通用户,并通过两个过滤器(admin过滤器和user过滤器)来控制不同用户的访问权限。管理员登录后,其用户名将被存入session的admin元素中,而普通用户则存入customer元素。过滤器检查session中的元素以确定用户类型并决定是否允许访问特定资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,思路:

>判断用户是否登录

>>>未登录

>>>>设置权限不能访问。

>>>登录

>>>>管理员登录,将用户名放入session的admin元素中

>>>>普通用户登录,将用户名放到session的customer元素中

2,登录servlet内容

//判断管理员还是普通用户...
                if(db_username.contains("admin"))
                    {
                        request.getSession().setAttribute("admin", "1");
                        request.getRequestDispatcher("glmain.jsp").forward(request, response);
                    }
                else
                    request.getSession().setAttribute("customer","2" );
                //比对成功后跳转成功页面
                    request.getRequestDispatcher("Index").forward(request, response);
                }


3,两个过滤器

admin过滤器:

package com.yanqing.filter;

import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Servlet Filter implementation class AdminFilter
 */
@WebFilter("/admin/*")
public class AdminFilter implements Filter {

   
    public AdminFilter() {
       
    }

    /**
     * @see Filter#destroy()
     */
    public void destroy() {
        
    }

    
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        HttpServletRequest req=(HttpServletRequest) request;
        HttpServletResponse res=(HttpServletResponse) response;
        String admin=(String) req.getSession().getAttribute("admin");
        if(admin!=null)
            {
                chain.doFilter(request, response);
                return;
            }
        else
            response.getWriter().write("you connt");
        
        
    }

    public void init(FilterConfig fConfig) throws ServletException {
        
    }

}

 

user过滤器:

package com.yanqing.filter;

import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;

/**
 * Servlet Filter implementation class UserLFilter
 */
@WebFilter("/user/*")
public class UserLFilter implements Filter {

    /**
     * Default constructor.
     */
    public UserLFilter() {
        // TODO Auto-generated constructor stub
    }

    /**
     * @see Filter#destroy()
     */
    public void destroy() {
        // TODO Auto-generated method stub
    }

    /**
     * @see Filter#doFilter(ServletRequest, ServletResponse, FilterChain)
     */
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        HttpServletRequest req=(HttpServletRequest) request;
        String admin=(String) req.getSession().getAttribute("admin");
        String customer=(String) req.getSession().getAttribute("customer");
        System.out.println(admin);
        System.out.println(customer);
        if(admin!=null)
            {
                chain.doFilter(request, response);
                return;
            }
        
        
        if(customer!=null)
                {
                    chain.doFilter(request, response);
                    return;
                }
            else
                response.getWriter().write("no login");
            
        }
        
    

    /**
     * @see Filter#init(FilterConfig)
     */
    public void init(FilterConfig fConfig) throws ServletException {
        // TODO Auto-generated method stub
    }

}

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值