利用Filter限制用户浏览权限

在一个系统中通常有多个权限的用户。不同权限用户的可以浏览不同的页面。使用Filter进行判断不仅省下了代码量,而且如果要更改的话只需要在Filter文件里动下就可以。
以下是Filter文件代码:

  1. package cn.itkui.filter;   
  2.   
  3. import java.io.IOException;   
  4.   
  5. import javax.servlet.Filter;   
  6. import javax.servlet.FilterChain;   
  7. import javax.servlet.FilterConfig;   
  8. import javax.servlet.ServletException;   
  9. import javax.servlet.ServletRequest;   
  10. import javax.servlet.ServletResponse;   
  11. import javax.servlet.http.HttpServletRequest;   
  12.   
  13. public class RightFilter implements Filter {   
  14.   
  15.     public void destroy() {   
  16.            
  17.     }   
  18.   
  19.     public void doFilter(ServletRequest sreq, ServletResponse sres, FilterChain arg2) throws IOException, ServletException {   
  20.         // 获取uri地址   
  21.         HttpServletRequest request=(HttpServletRequest)sreq;   
  22.         String uri = request.getRequestURI();   
  23.         String ctx=request.getContextPath();   
  24.         uri = uri.substring(ctx.length());   
  25.         //判断admin级别网页的浏览权限   
  26.         if(uri.startsWith("/admin")) {   
  27.             if(request.getSession().getAttribute("admin")==null) {   
  28.                 request.setAttribute("message","您没有这个权限");   
  29.                 request.getRequestDispatcher("/login.jsp").forward(sreq,sres);   
  30.                 return;   
  31.             }   
  32.         }   
  33.         //判断manage级别网页的浏览权限   
  34.         if(uri.startsWith("/manage")) {   
  35.             //这里省去   
  36.             }   
  37.         }   
  38.         //下面还可以添加其他的用户权限,省去。   
  39.   
  40.     }   
  41.   
  42.     public void init(FilterConfig arg0) throws ServletException {   
  43.            
  44.     }   
  45.   
  46. }   

以下是在web.xml需要加入的代码

  1. <!-- 判断页面的访问权限 -->  
  2.   <filter>  
  3.      <filter-name>RightFilter</filter-name>  
  4.       <filter-class>cn.itkui.filter.RightFilter</filter-class>  
  5.   </filter>  
  6.   <filter-mapping>  
  7.       <filter-name>RightFilter</filter-name>  
  8.       <url-pattern>/admin/*</url-pattern>  
  9.   </filter-mapping>  
  10.   <filter-mapping>  
  11.       <filter-name>RightFilter</filter-name>  
  12.       <url-pattern>/manage/*</url-pattern>  
  13.   </filter-mapping>  

这篇日志在BlogJava帖过,今天般到JE来,本人原创作品!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值