日期:2014-05-17 浏览次数:20796 次
?
除了我们开头说的aop的那写通用场景外,我个人还比较喜欢用的还有一个场景。
?
前提: 任何系统都有 用户、数据这2个主体。 往往用户的身份不同,看到的数据也不同,如果每条数据查询的sql,都手写一条where userId= xxx 肯定也很麻烦,而且一旦逻辑改动,修改起来更麻烦。这个时候Aspectj就可以用上了。(以下Demo.Dao层为Hibernate )
?
?
?
具体例子: 某物业管理系统假设有 楼栋管理员这个角色(以这个为例,这个角色比较有代表性),也就是说:每栋楼一个管理员,没个管理员只能查看自己的数据,然后当然后还Super Admin这类的角色。现在如果根据房号查询这个房屋的 缴费信息(物管,水电,煤气。。。。。),你会怎么做?
?
说下我的做法吧。
?
1、用户登陆: 用ThreadLocal保存用户信息。
2、定义一个Annotaion.定义一些我需要的属性。
3、编写aspectj. 拦截Service package中,有该注解的 方法的控制流 中的 query() 和 SQLQuery(),(大家都知道Hibernate执行查询都是这2个方法的)。这句话有点绕,用 aspectj的语法来表示是这样的:pointcut p1() : cfow(call(* com.wuye.service..*(..)) && @YourAnnotaion) 拿到有注解的service方法的控制流。 pointcut p2() : call(* query(..))
然后 p1 && p2 组合成一个新的 pointcut.
4、在aspectj中,thisJoinPoint.getArgs()我们就可获取到SQLQuery() Query()的参数, 那到Sql.做修改。 剩下的知道了。