自定义的action过滤器  需要继承自ActionFilterAttribute 接口

OnActionExecuting:  在方法执行之前执行

OnActionExecuted:  方法的逻辑代码执行完成之后触发

OnResultExecuting: 方法在准备放回结果的时候触发

OnResultExecuted:方法返回结果之后触发

    /// <summary>
/// 自定义的action过滤器 和result过滤器
/// </summary>
public class ActionFilterDemo : ActionFilterAttribute
{
/// <summary>
/// 在方法执行之前被触发
/// </summary>
/// <param name="filterContext"></param>
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
//判断如果在控制器上贴有SkipAttribute特性标签则跳过下面代码的执行
if (filterContext.ActionDescriptor.ControllerDescriptor.IsDefined(typeof(SkipAttribute), false))
{
return;
} filterContext.HttpContext.Response.Write("1 、OnActionExecuting----<br />"); //1.0 获取触发当前方法的action名称
var actionName = filterContext.ActionDescriptor.ActionName; //2.0 获取action方法所在的控制器
var cName = filterContext.ActionDescriptor.ControllerDescriptor.ControllerName;
filterContext.HttpContext.Response.Write(" 1.1 、控制器+action=" + cName + actionName + "<br />"); //3.0 获取action的参数
string res = "无参数";
var prmas = filterContext.ActionParameters;
if (prmas != null && prmas.Any())
{
res = "";
//打印参数名称和值
foreach (var ps in prmas)
{
res += "参数名称=" + ps.Key + ",参数值=" + ps.Value + " | ";
}
}
filterContext.HttpContext.Response.Write(" 1.2 、参数结果:" + res + "<br />"); //4.0 获取当前action上的指定的特性标签HttpGet
object[] atts = filterContext.ActionDescriptor.GetCustomAttributes(typeof(HttpGetAttribute), false);
var allAtts = filterContext.ActionDescriptor.GetCustomAttributes(false);//获取所有的特性标签 //4.0.1 判断当前action方法上是否贴有HttpGet的特性标签
bool isok = filterContext.ActionDescriptor.IsDefined(typeof(HttpGetAttribute), false); //5.0 获取当前aciton所在的控制器上的特性标签和判断特性标签
var allcatts = filterContext.ActionDescriptor.ControllerDescriptor.GetCustomAttributes(false);
var isOK1 = filterContext.ActionDescriptor.ControllerDescriptor.IsDefined(typeof(HttpGetAttribute), false); //6.0 其实OnActionExecuting是在方法执行之前执行的 那么当然也可以用来改造验证同意登陆啦 下面是我自己的尝试 //获取当前登录url 登陆完毕需要跳转回来的
bool isLogin=false; //根据项目的登陆方式判断是否登陆
if (!isLogin)
{
string call_back = System.Web.HttpContext.Current.Request.Url.ToString();
ContentResult result = new ContentResult();
result.Content = "<script>alert('请先登录');window.location.href='http://www.xxoo.com/Passport/Login?callback_url=" + call_back + "'</script>";
filterContext.Result = result;
return;
}
base.OnActionExecuting(filterContext);
} /// <summary>
/// 方法逻辑代码执行以后被触发
/// </summary>
/// <param name="filterContext"></param>
public override void OnActionExecuted(ActionExecutedContext filterContext)
{
filterContext.HttpContext.Response.Write("3 、OnActionExecuted----<br />");
base.OnActionExecuted(filterContext);
} /// <summary>
/// 方法准备返回结果的时候被触发
/// </summary>
/// <param name="filterContext"></param>
public override void OnResultExecuting(ResultExecutingContext filterContext)
{
filterContext.HttpContext.Response.Write("4 、OnResultExecuting----<br />");
base.OnResultExecuting(filterContext);
} /// <summary>
/// 方法返回结果后被触发
/// </summary>
/// <param name="filterContext"></param>
public override void OnResultExecuted(ResultExecutedContext filterContext)
{
filterContext.HttpContext.Response.Write("6 、OnResultExecuted----<br />");
base.OnResultExecuted(filterContext);
}
}

自定义异常过滤器 继承自HandleErrorAttribute接口

OnException: 该接口 用户不扣action中没有被try{} catch包括的异常

/// <summary>
/// 作用:用于捕获action中的未被try{}catch{}捕获的异常
/// </summary>
public class ExpAttribute : HandleErrorAttribute
{
public override void OnException(ExceptionContext filterContext)
{ //1.0获取异常信息
Exception exp = filterContext.Exception; //2.0 将信息写入日志或者db中方便查询
// System.IO.File.AppendAllText(filterContext.HttpContext.Server.MapPath("/Log/log.txt"), exp.ToString()); //3.0 通知MVC框架,现在这个异常已经被我处理掉,你不需要将黄页显示给用户
filterContext.ExceptionHandled = false; //4.0 跳转到错误提醒页面
//filterContext.Result
filterContext.HttpContext.Response.Redirect("/Error/Error", true); base.OnException(filterContext);
}
}

其实自定义错误页面还可以换个姿势

在Web.config中配置

<customErrors mode="Off" defaultRedirect="Error">       这里的Error页面是views/shared/Error.cshtml页面    
<!--<error statusCode="404" redirect="/Error/404" />-->  statusCode  定义的 是错误类型      这里的redirect    是自定义的错误页面
</customErrors>

------------------------------最后将过滤器注入到Global.asax文件中

public class FilterConfig
{
public static void RegisterGlobalFilters(GlobalFilterCollection filters)
{
filters.Add(new HandleErrorAttribute()); //将ActionFilterDemo 注册成为一个全局过滤器,实现当前网站中的任何action方法被执行的时候都
//会触发过滤器中的相关方法
filters.Add(new ActionFilterDemo());
filters.Add(new AuthAttribute()); filters.Add(new ExpAttribute());
}
}
 public class MvcApplication : System.Web.HttpApplication
{
protected void Application_Start()
{
AreaRegistration.RegisterAllAreas(); WebApiConfig.Register(GlobalConfiguration.Configuration);
FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); //自定义的过滤器
RouteConfig.RegisterRoutes(RouteTable.Routes);
BundleConfig.RegisterBundles(BundleTable.Bundles);
}
}

最新文章

  1. bootstrap双日历插件实例化
  2. You Only Live Once
  3. CocoStudio教程三:认识并利用CocoStudio的果实 运行2.2.1版本
  4. 关于GC进行垃圾回收的时机
  5. 域名解析-delphi 源码
  6. [转] Spring Boot and React hot loader
  7. BZOJ 3572 世界树(虚树)
  8. C++学习笔记——STL(标准模板库)
  9. UNIX网络编程——ioctl 函数的用法详解
  10. node基础—process对象(管理进程)
  11. 第五篇:数据备份、pymysql模块
  12. 前端的重要部分js
  13. Python 扩展技术总结(转)
  14. Kubernetes中的亲和性与反亲和性
  15. P2157 [SDOI2009]学校食堂 (dp+状态压缩)
  16. typescript泛型类 泛型方法
  17. C++访问二维数组元素
  18. 进阶篇:5.1)极值法(Worst Case ,WC)
  19. python对于0x01的处理
  20. 【ARC069F】Flags 2-sat+线段树优化建图+二分

热门文章

  1. 【IO流】java中文件路径(相对路径、绝对路径)相关类及方法
  2. python学习笔记:接口开发——flask Demo实例
  3. html5中利用FileReader来读取文件。
  4. JavaScript之 ------ 函数(一般函数、动态函数、匿名函数)
  5. Spring Data JPA one to one 共享主键关联
  6. FrameWork内核解析之WindowManagerService(一)中篇
  7. 27-python基础-python3-异常处理(try except)
  8. Puppeteer自动化测试cnode.js中文社区
  9. CSV模块的使用
  10. windows API 第22篇 WTSGetActiveConsoleSessionId