用json文件声明Aop切片


需使用的类

  1. * org.nutz.ioc.aop.config.impl.JsonAopConfigration

看看一个示例的ioc配置文件

  1. 配置示例:
  2. {{{<json>
  3. var ioc = {
  4. log : {
  5. type :'org.nutz.aop.interceptor.LoggingMethodInterceptor'
  6. },
  7. myMI : {
  8. type : 'org.nutz.ioc.aop.config.impl.MyMI'
  9. },
  10. pet2 : {
  11. type : "org.nutz.ioc.aop.config.impl.Pet2"
  12. },
  13. $aop : {
  14. type : 'org.nutz.ioc.aop.config.impl.JsonAopConfigration',
  15. fields : {
  16. itemList : [
  17. ['.+','toString','ioc:log'],
  18. ['.+','.+','ioc:myMI'],
  19. ['.+','.+','org.nutz.ioc.aop.config.impl.MyMI2','false']
  20. ]
  21. }
  22. }
  23. }
  24. }}}
  25. 可以看到, 除了$aop这个beanName外,其他的与普通的ioc配置文件没有任何区别.
  26. $aop ,其实是org.nutz.ioc.aop.config.AopConfigration接口的IOCNAME字段的值,
  27. 只有你声明这个名字,且类型为这个接口的实现,就能轻易的配置Ioc.
  28. 估计你已经猜到,org.nutz.ioc.aop.config.impl.JsonAopConfigration就是其中一个实现!
  29. 细看这个部分代码:
  30. {{{<JSON>
  31. fields : {
  32. itemList : [
  33. ['.+','toString','ioc:log'],
  34. ['.+','.+','ioc:myMI'],
  35. ['.+','.+','org.nutz.ioc.aop.config.impl.MyMI2','false']
  36. ]
  37. }
  38. }}}
  39. 使用JsonAopConfigration,只需要为其itemList赋值.
  40. 需要什么值? 对,一个数组.
  41. 数组的每一行,对应一条规则:
  42. {{{<JSON>
  43. ['.+','toString','ioc:log'],
  44. ['.+','.+','ioc:myMI']
  45. ['com\.wendal\.nutz\..+','get.+','org.nutz.ioc.aop.config.impl.MyMI2','false']
  46. }}}
  47. 规则如下:
  48. * 第一个值,对应className,必选,用于匹配类的全称的正则表达式
  49. * 第二个值,对应methodName,必选,用于匹配方法名的正则表达式
  50. * 第三个值,对应interceptorName,必选,如果以ioc:开头,则代表对于ioc容器的一个对象,否则,将认为是一个类名
  51. * 第四个值,对应singleton,可选,仅当interceptorName为类名时有效