权限过滤器类

 

package com.filters;

import java.io.IOException;
import java.util.List;

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.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import com.pojos.Menus;
import com.pojos.Users;

public class PowerFilter implements Filter {

 public void destroy() {
  // TODO Auto-generated method stub

 }

 public void doFilter(ServletRequest arg0, ServletResponse arg1,
   FilterChain arg2) throws IOException, ServletException {
  //强制转化为子类
  HttpServletRequest request=(HttpServletRequest) arg0;
  HttpServletResponse response=(HttpServletResponse) arg1;
  
  //小编一下码
  request.setCharacterEncoding("utf-8");
  response.setCharacterEncoding("html/text;charset=utf-8");
  
  //取地址上输入路径 /user.do 工程名和?之间
  String path=request.getServletPath();
  //取?后面的参数  eg:id=2
  String param=request.getQueryString();
  //把请求路径拼起来
  if(param!=null&&param.length()>0)
  {
   path=path+"?"+param;
  }
  //System.out.println("path:"+path);
  
  // 取session判断是否已经登录
  HttpSession session=request.getSession();
  Users user=(Users) session.getAttribute("user");
  //判断是否是admin登录,如果是都可以操作
  if(user!=null&&user.getUsername()=="admin")
  {
   arg2.doFilter(request, response);
   return ;
  }
  
  // 无条件可以过的是登陆有关(登陆界面和登陆action)
  if(path.equals("/index.jsp")||path.equals("/user.do?p=login")||path.equals("/"))
  {
   //通过
   arg2.doFilter(request, response);
   return ;
  }
  
  //没有登录等情况
  if(user==null)
  {
   //getContextPath()得工程名
   response.getWriter().print("<script>alert('请先登录');location='"+request.getContextPath()+"/index.jsp'</script>");
   arg2.doFilter(request, response);
   return ;
  }
  
  // 已经登录  主界面只要登陆就可以用
  if(path.startsWith("/background/"))
  {
   arg2.doFilter(request, response);
   return ;
  }
  
  // 其它界页还要看权限
  List<Menus> menus=(List) session.getAttribute("menus");
  for (Menus m : menus) {
   //System.out.println("权限url:"+m.getUrl());
   String url=m.getUrl();
   if(url!=null&& path.startsWith("/"+url));
   {
    arg2.doFilter(request, response);
    return ;
   }
  }
  response.getWriter().print("<script>alert('您没有足够的权限!')</script>");
 }

 public void init(FilterConfig arg0) throws ServletException {
  // TODO Auto-generated method stub

 }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值