AOP(面向切面)的粗俗理解
百度百科的解释:AOP主要实现的目的是针对业务处理过程中的切面进行提取,它所面对的是处理过程中的某个步骤或阶段,以获得逻辑过程中各部分之间低耦合性的隔离效果。
一个比较绕的概念,简单来说就是把不影响业务流程的功能独立封装出来,不用在需要使用该功能的方法中显示调用该方法。
代码为例:
public void Edit(Book book) { //验证用户是否有权限的代码 //方法的主体逻辑 //记录操作日志的代码 }
在上面的方法中,只有主体逻辑才是这个方法的核心,权限和日志都不影响该逻辑的具体实现,如果把具体方法都写在这里则会显得臃肿,同时耦合度很高,如果出现多个地方拥有相同代码一旦变更则变得很麻烦,我们可以将权限和日志拆分成两个独立方法,封装到不同类里面去,从而使得方法内部耦合性降低,方法和类的功能单一。
public class Role
{ public static bool IsOk(User user)
{ //验证权限的具体代码 } } ; public class Log
{ public static void LogText(User user,Book book)
{ //记录日志的具体代码 } } ; /*上文提到的方法*/ public void Edit(Book book)
{ if(Role.IsOk(Session["User"])) { // do something... }else{ // do something... } //方法的主体逻辑 Log.LogText(Session["User"],book); }
以上是常规方法中用到的解耦方法,而有了AOP之后怎么做呢,拿过ASP.NET MVC的滤器举例
public class RoleFilterAttribute : ActionFilterAttribute { public override void OnActionExcuting(ActionExecutingContext filterContext) { //验证权限代码 } }; public class LogFilterAttribute : ActionFilterAttribute { public override void OnActionExcuted(ActionExecutingContext filterContext) { //记录日志代码 } }; /*原来的方法*/ [LogFilter] [RoleFilter] public void Edit(Book book){ //主体逻辑 }
有了切面之后,跟主体逻辑无关的变更只需要在过滤器中更改就可以了,原来的方法去除这些无关的功能后代码显得更清晰。
至于过滤器怎么实现在Eidt执行前调用权限验证或者在执行结束后记录日志,则已经超出面向切面概念的理解。