AOP — 在Mvc中的使用

Jul 10, 2017 10:38:44 AM

作者:wendal

重要提醒:

  • AOP只能用于Ioc Bean对象, 即从Ioc容器获取的对象, 不是直接new一个对象就能aop的
  • 自定义Aop拦截器,一般情况下别"吃掉"异常, 因为事务拦截器需要检测到异常才能回滚
  • 留意拦截器的先后顺序

示例配置

主模块的IocBy配置

  1. @IocBy(args={
  2. "*js", "ioc/", // 读取ioc/下的js/json配置文件
  3. "*anno", "net.wendal.nutzbook", // 扫描package下的ioc注解
  4. "*tx", // 启用内置的事务拦截器 例如: @Aop(TransAop.txREAD_COMMITTED)
  5. "*async", "48", // 启用异步执行注解拦截器, 后面的48是线程池大小. 即注解@Async
  6. "*net.wendal.nutzbook.aop.DemoAopLoader" // 自定义aop注解加载器
  7. })

一个演示的入口类

  1. @At("/user")
  2. @IocBean
  3. public class UserAction {
  4. @Inject
  5. protect Dao dao;
  6. @At
  7. @Ok("json") // 前端ajax
  8. @Aop(TransAop.txREPEATABLE_READ)
  9. public Object login(@Param("name")String name, @Param("passwd")String passwd) {
  10. if (dao.count(User.class, Cnd.where("name", "=", name).and("password", "=", passwd) > 0)
  11. return true;
  12. return false;
  13. }
  14. @At("/check/email")
  15. @Async // 异步执行,不会等方法真正执行
  16. public void vaildEmail() {
  17. // ... 发邮件等等
  18. }
  19. @At("/check/log")
  20. @SysLog // 自定义注解,后面会介绍
  21. public void justCheckLog() {
  22. /// .....
  23. }
  24. }

自定义SysLog的注解类

  1. @Retention(RetentionPolicy.RUNTIME) // 必须带这个,不然读取不到的
  2. @Target({ElementType.METHOD}) // aop,一般指方法
  3. @Documented // 记录到javadoc
  4. public @interface SysLog {
  5. }

处理类

  1. package net.wendal.nutzbook.aop;
  2. public class DemoAopLoader extends SimpleAopMaker<SysLog> {
  3. public List<? extends MethodInterceptor> makeIt(SysLog sysLog, Method method, Ioc ioc) {
  4. return Arrays.asList(new SysLogMethodInterceptor());
  5. }
  6. }
  7. class SysLogMethodInterceptor implements MethodInterceptor {
  8. private static final Log log = Logs.get();
  9. public void filter(final InterceptorChain chain) throws Throwable {
  10. log.debug("hi");
  11. chain.doChain(); // 继续下一个拦截器, 如果要终止执行,不调用该方法即可
  12. log.debug("byte");
  13. }
  14. }

本页面的文字允许在知识共享 署名-相同方式共享 3.0协议GNU自由文档许可证下修改和再使用。

原文: http://nutzam.com/core/aop/aop_mvc.html