Guice предоставляет способ создания привязок с объектами значений или константами. Рассмотрим случай, когда мы хотим настроить URL JDBC.
Внедрить с помощью аннотации @Named
@Inject public void connectDatabase(@Named("JBDC") String dbUrl) { //... }
Это может быть достигнуто с помощью метода toInstance ().
bind(String.class).annotatedWith(Names.named("JBDC")).toInstance("jdbc:mysql://localhost:5326/emp");
Полный пример
Создайте Java-класс с именем GuiceTester.
GuiceTester.java
import com.google.inject.AbstractModule; import com.google.inject.Guice; import com.google.inject.Inject; import com.google.inject.Injector; import com.google.inject.name.Named; import com.google.inject.name.Names; public class GuiceTester { public static void main(String[] args) { Injector injector = Guice.createInjector(new TextEditorModule()); TextEditor editor = injector.getInstance(TextEditor.class); editor.makeConnection(); } } class TextEditor { private String dbUrl; @Inject public TextEditor(@Named("JDBC") String dbUrl) { this.dbUrl = dbUrl; } public void makeConnection() { System.out.println(dbUrl); } } //Binding Module class TextEditorModule extends AbstractModule { @Override protected void configure() { bind(String.class) .annotatedWith(Names.named("JDBC")) .toInstance("jdbc:mysql://localhost:5326/emp"); } }
Выход
Скомпилируйте и запустите файл, вы увидите следующий вывод.