Actframework依赖注入 II - 注入对象类型

前端之家收集整理的这篇文章主要介绍了Actframework依赖注入 II - 注入对象类型前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

1. 框架内置绑定

在ActFramework中有大量的服务和组件都可以直接使用依赖注入,其中包括

    @H_301_5@ActionContext - Encapsulate all data/info relevant to an HTTP request context @H_301_5@H.Session - HTTP request session. Also available via actionContext.session() @H_301_5@H.Flash - HTTP request flash. Also available via actionContext.flash() @H_301_5@H.Request - HTTP request. Also available via actionContext.req() @H_301_5@H.Response - HTTP response. Also available via actionContext.resp() @H_301_5@CliContext - Encapsulate all data/facilities relevant to a CLI session @H_301_5@CliSession (Since act-0.6.0) - CLI session @H_301_5@MailerContext - Mailer method context @H_301_5@ActContext - A generic ActContext depends on the current computation environment,could be either ActionContext,CliContext or MailerContext or null @H_301_5@Logger - The Act.LOGGER instance @H_301_5@UserAgent - The user agent if in a request handling context @H_301_5@AppConfig - The application configuration object @H_301_5@AppCrypto - The application crypto object @H_301_5@CacheService - The App.cache() cache service @H_301_5@EventBus - The application's event bus @H_301_5@Locale - Could be ActContext.locale() or AppConfig.locale() if there is no context

1.1 应用服务组件

    @H_301_5@DbServiceManager @H_301_5@MailerService @H_301_5@Router @H_301_5@CliDispatcher @H_301_5@AppJobManager

2. Dao

目前支持EbeanDaoMorphiaDao两种分别用于访问sql和MongoDB数据库

// Demonstrate inject to field
@Controller("user")
public class UserService {

    @javax.inject.Inject
    private MorphiaDao<User> userDao;

    @PostAction
    public void create(User user) {
        userDao.save(user);
    }

}
// Demonstrate inject to parameter
@Controller("user")
public class UserService {

    @PostAction
    public void create(User user,MorphiaDao<User> userDao) {
        userDao.save(user);
    }

}

如果应用有自定义的Dao,可以直接注入:

// The Model
@Entity("user")
public class User extends MorphiaModel<User> {
    
    public String email;
    ...

    public static class Dao extends MorphiaDao<User> {
        public User findByEmail(String email) {
            return findOneBy("email",email);
        }
    }
}
// The controller
@Controller("user")
public class UserService {

    @javax.inject.Inject
    private User.Dao userDao;

    @GetAction("{email}")
    public User findByEmail(String email) {
        return userDao.findByEmail(email);
    }

}

3. 可构造对象

任何拥有public缺省构造函数或者带有@Inject构造函数的类均可被注入,例如:

// A class with public default constructor
public class Foo {
    public Foo() {...}
}
// A class with Inject constructor
public class Bar {
    @javax.inject.Inject
    public Bar(Foo foo) {...}
}

上面的FooBar都可以用于依赖注入:

public class XxxController {
    @Inject Foo foo;
    @Inject Bar bar;

    ...
}

注意 可构造对象不能直接用于参数注入

public class XxxController {

    // foo and bar won't be able to injected throght DI
    // instead they will be deserialized from form parameters
    @PostAction("/xxx")
    public void xxxAction(Foo foo,Bar bar) {
    }
}

但是可以通过@Provided注解来指定使用依赖注入

public class YyyController {

    // this time foo and bar will be injected through DI
    @PostAction("/yyy")
    public void xxxAction(@Provided Foo foo,@Provided Bar bar) {
    }
}

4. 应用自定义的绑定

假设应用自己定义了接口或抽象类,并且定义了绑定,可以直接使用依赖注入

// The interface
public interface MyService {
    void service();
}
// The implemention one
public class OneService implements MyService {
    public void service() {Act.LOGGER.info("ONE is servicing");}
}
// The implemention two
public class TwoService implements MyService {
    public void service() {Act.LOGGER.info("TWO is servicing");}
}
// Define bindings
public class MyModule extends org.osgl.inject.Module {
    protected void configure() {
        bind(MyService.class).to(OneService.class);
        bind(MyService.class).named("two").to(TwoService.class);
    }
}
// Inject the service
public class Serviced {
    @Inject
    private MyService one;

    @Inject
    @Named("two")
    private MyService two;
}

链接

猜你在找的设计模式相关文章