C#实现aop思想有两种方式
一种是MVC框架中带有的过滤器,只要实现控制器的基类就可以使用。配合attribute可以实现验证功能。因为webapi相当于没有页面的MVC,所以也可以使用。
** 另一种是使用attribute配合一些接口实现,该方式比上一种复杂,但更类似于java中spring提供的面向注解思想。只要在要切片的类上附加该attribute就可以使用**
方法在这
本篇讲第一种,也是比较简单的方式。
先创建一个控制器,集成Controller基类
public class BaseController : Controller
继承后可以重写两个父类中拥有的虚方法
/// <summary>
/// 这是MVC框架内的方法,作用是访问继承此类的类中的action会先执行OnActionExecuting方法
/// OnActionExecuting是Controller中的虚方法,此类继承Controller后重写
/// </summary>
/// <param name="context">有关当前请求和操作的信息</param>
public override void OnActionExecuting(ActionExecutingContext context)
{
base.OnActionExecuted(context);
}
/// <summary>
/// 在执行完类中的action后会执行OnActionExecuting方法
/// OnActionExecuting是Controller中的虚方法,此类继承Controller后重写
/// </summary>
/// <param name="context">有关当前请求和操作的信息</param>
public override void OnActionExecuted(ActionExecutedContext context)
{
base.OnActionExecuted(context);
}
如果要绕过某些action,可以配合attribute使用
[AttributeUsage(AttributeTargets.Method)]
public class AllowAnonymousAttribute : Attribute
{
//该特性仅用于标识方法,在此不做内容
}
在过滤器中识别该attribute,并作相应规避
//判断函数是否包括attribute
if (context.ActionDescriptor.GetType().GetCustomAttributes(typeof(AllowAnonymousAttribute), true).Length > 0)
{
//继续执行原本操作
base.OnActionExecuting(context);
}
//判断是否有登录的权限
if (IsAuthority())
{
//继续执行原本操作
base.OnActionExecuting(context);
}
else{
//此处拦截
}
最后目标控制器继承含有过滤器的类,就可以过滤目标控制器中的action了
public class HomeController : BaseController