一向都觉得.NET的Attribute好神秘。一个方框框住的东西,置身于类、方法的头部,本身不在类或方法里面,但又会起作用,有时作用还很大,仿佛充满了魔力。简直给人一种无冕之王,幕后之黑手的感觉!
某十几年前已经开始接触C#,却对这个Attribute充满了迷茫。原因固然跟本人懒惰成性,不思进取,从业十几年,不是“有十几年工作经验,而是一条经验用了十几年”有关,也因为我当初自学的C#教材,什么宝典,什么从入门到精通之类,都没有介绍这个东东。就算查,也不知道它叫啥。你看看:
后来有人叫它:特性。总算知道了。
其实Attribute本身就是一个类。换言之,它就是代码。虽然没有放在类、方法里面,只放在头部,好像就是个说明而已,但其实,它们本身就是代码的一部分。编译器、CLR能够识别、并处理它们,做出不同的反应,所以说到底,这有啥好神秘的?我只是脑筋转不过弯来罢了。
就是在我们自己的代码里面,也可以直接使用的:
protected override void OnActionExecuting(ActionExecutingContext filterContext){bool hasPermission = true;var permissionAttributes = filterContext.ActionDescriptor.GetCustomAttributes(typeof(PermissionAttribute), false).Cast<PermissionAttribute>();if (permissionAttributes == null || permissionAttributes.Count() == 0){//如果action没有指定权限,则继承controller的指定permissionAttributes = filterContext.ActionDescriptor.ControllerDescriptor.GetCustomAttributes(typeof(PermissionAttribute), false).Cast<PermissionAttribute>();}}
所谓的PermissionAttribute,是自己写的一个跟权限有关的特性
public class PermissionAttribute : FilterAttribute, IActionFilter{public List<int> Permissions { get; set; }public PermissionAttribute(params int[] parameters){Permissions = parameters.ToList();}}
可以用在action或controller上
[Permission((int)EnumBusinessPermission.DictionaryAdmin)]public ActionResult Create(){SysField model = new SysField();return View("Edit", model);}