MVC权限过滤器

第一步:
创建过滤器类:

public class PowerFilter : ActionFilterAttribute
    {
        public static string newRouteData;
        //该方法会在action方法执行之前调用  
        public override void OnActionExecuting(ActionExecutingContext filterContext)
        {
            
        }
        //该方法会在action方法执行之后调用  
        public override void OnActionExecuted(ActionExecutedContext filterContext)
        {
            /* 先查询数据库的权限表
             * 如果进入的页面在权限表中,则运行以下的First,反之直接return
             * 然后判断用户的角色权限中是否有该页面的权限
             * 有则直接return ,无则返回上一页
             * 注意:如果需要判断权限的视图,必须要有相对应的action,否则不会经过过滤器,也就不会判断
             */
            /*----------------------------------避免麻烦,先不使用数据库---------------------------------*/

            var RouteData = filterContext.RouteData.Values;
            newRouteData = string.Format("/{0}/{1}", RouteData["controller"], RouteData["action"]);
            var IsPower = (from s in AllPower.PowerList select s).Where(t => t.PowerHref == newRouteData).FirstOrDefault();     //先查询该action是否需要判断权限
            if (IsPower != null)
            {

                /*----------------------------------First----------------------------------------------------------*/
                var HavePower = (from u in UserPower.UserPowerList 			
                                 join p in AllPower.PowerList on u.Powerid equals p.Powerid where p.PowerHref == newRouteData && u.Userid==LoginHelper.CheckCookie().UserID
                                 select new
                                 {
                                     u.Powerid
                                 }
                                 ).FirstOrDefault();
                if (HavePower !=null)       //判断用户是否具有该页面的权限
                {
                    return;
                }
                else
                {
                    filterContext.HttpContext.Response.Write("<script>alert('您没有权限')</script>");
                    //如果端口号不属于当前项目,也会等于空,则进入项目首页,否则返回之前的页面
                    string HistoryUrl = filterContext.HttpContext.Request.UrlReferrer==null? "/Home/Index": filterContext.HttpContext.Request.UrlReferrer.ToString();   
                    filterContext.Result = new RedirectResult(HistoryUrl);
                }
                /*---------------------------------------------------------------------------------------------*/
            }
            return;
        }
    }

第二步:
在App_Start中的FilterConfig中添加权限过滤器

public class FilterConfig
    {
        public static void RegisterGlobalFilters(GlobalFilterCollection filters)
        {
            filters.Add(new HandleErrorAttribute());
            filters.Add(new PowerFilter());     //权限过滤器
        }
    }

第三步:
在Global.asax中注册自定义的过滤器

public class MvcApplication : System.Web.HttpApplication
    {
        protected void Application_Start()
        {
            AreaRegistration.RegisterAllAreas();
            RouteConfig.RegisterRoutes(RouteTable.Routes);

            //添加自定义的过滤器
            FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
        }
    }
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring MVC的拦截器是一种应用于请求和响应过程中的过滤器,可以用于对请求进行预处理、对响应进行后处理,以及在请求到达处理程序之前或处理程序返回响应之后执行某些操作。 在Spring MVC中,拦截器是通过实现HandlerInterceptor接口来实现的。该接口定义了三个方法,分别是preHandle()、postHandle()和afterCompletion()。 - preHandle()方法在请求到达处理程序之前执行,可以用于进行身份验证、权限校验等操作,如果该方法返回false,则请求将被拦截并不会到达处理程序。 - postHandle()方法在处理程序完成请求处理后但尚未返回响应时执行,可以用于修改响应或添加一些额外的信息。 - afterCompletion()方法在请求处理完成后执行,无论成功或失败都会执行,可以用于进行资源清理等操作。 要使用拦截器,需要在Spring配置文件中进行配置,并将其注册到DispatcherServlet中。 下面是一个简单的拦截器示例,用于记录请求处理时间: ```java public class TimeInterceptor implements HandlerInterceptor { private static final Logger LOGGER = LoggerFactory.getLogger(TimeInterceptor.class); @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { request.setAttribute("startTime", System.currentTimeMillis()); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { long startTime = (long) request.getAttribute("startTime"); long endTime = System.currentTimeMillis(); LOGGER.info("Request URL: {} , Time: {}ms", request.getRequestURL(), endTime - startTime); } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // do nothing } } ``` 在Spring配置文件中进行配置: ```xml <mvc:interceptors> <bean class="com.example.TimeInterceptor" /> </mvc:interceptors> ``` 这样,每次请求处理完成后,日志中就会打印该请求的处理时间,以便进行性能优化。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值