Aop.get(...) 可以在任意时空创建对象并且对其进行依赖注入,例如:
Service service = Aop.get(Service.class);
以上代码会创建 Service 对象,如果 Service 中使用了 @Before 配置过拦截器,那么会生效,如果 Service 中的属性使用了 @Inject,则会被注入依赖对象。
Aop.inject(...) 可以在任意时空对目标对象进行注入,该方法相对于 Aop.get(...) 方法少一个对象创建功能:
Service service = new Service(...); Aop.inject(service);
以上代码将会对 Service 类中使用 @Inject 注解过的属性进行依赖注入。
AopManager 用于管理 Aop 的各种配置
addMapping 用于建立接口、抽象类到其实现类之间的映射关系,例如:
AopManager.me().addMapping(Service.class, MyService.class);
通过上面的映射,下面的代码将会为 Serivce 创建 MyService 对象,而非 Service 对象:
// 这里获取到的是 MyService 对象 Aop.get(Service.class); // 这里被注入的是 MyService 对象 @Inject Service service;
AopManager.me().addMapping(...) 的用途是为接口、抽象类指定被注入的具体实现类。
由于 Aop 创建对象时不支持为构造方法传递参数,所以还需提供 addSingletonObject(...) 添加单例对象:
// Service 类的构造方法中传入了两个参数 Service service = new Service(paraAaa, paraBbb); AopManager.me().addSingletonObject(service);
上面代码添加完成以后,可以在任何地方通过下面的方式获取单例对象:
// 获取时使用单例对象 service = Aop.get(Service.class); // 注入时也可以使用前面配置的单例对象 @Inject Service service;
在添加为单例对象之前还可以先为其注入依赖对象:
Service service = new Service(paraAaa, paraBbb); // 这里是对 Service 进行依赖注入 Aop.inject(service); // 为单例注入依赖以后,再添加为单例供后续使用 AopManager.me().addSingletonObject(service);
setAopFactory(...) 用于用户扩展出 AopFactory 实现类,实现更多扩展性功能,例如 jboot 项目中对于注入远程访问对象的扩展:https://gitee.com/JbootProjects/jboot/blob/master/src/main/java/io/jboot/aop/JbootAopFactory.java ,JbootAopFactory.java 中的 doInjectRPC 即注入远程过程调用的实现类。