- Spring DI - Discussion
- Spring DI - Useful Resources
- Spring DI - Quick Guide
- Spring DI - Non-Static Factory
- Spring DI - Static Factory
- Spring DI - Autowiring Constructor
- Spring DI - Autowiring ByType
- Spring DI - Autowiring ByName
- Spring DI - Autowiring
- Spring DI - Map Ref Setter
- Spring DI - Map Setter
- Spring DI - Collection Ref Setter
- Spring DI - Collections Setter
- Spring DI - Inner Beans Setter
- Spring DI - Setter Based
- Spring DI - Map Ref Constructor
- Spring DI - Map Constructor
- Spring DI - Collection Ref Constructor
- Spring DI - Collections Constructor
- Spring DI - Inner Beans Constructor
- Spring DI - Constructor Based
- Spring DI - Create Project
- Spring Dependency Injection
- Spring DI - IOC Containers
- Spring DI - Environment Setup
- Spring DI - Overview
- Spring DI - Home
Selected Reading
- Who is Who
- Computer Glossary
- HR Interview Questions
- Effective Resume Writing
- Questions and Answers
- UPSC IAS Exams Notes
Spring DI - Static Factory
Spring provides an option to inject dependency using factory-method attribute.
Example
The following example shows a class TextEditor that can only be dependency-injected using pure setter-based injection.
Let s update the project created in
chapter. We re adding following files −TextEditor.java − A class containing a SpellChecker as dependency.
SpellChecker.java − A dependency class.
MainApp.java − Main apppcation to run and test.
Here is the content of TextEditor.java file −
package com.tutorialspoint; pubpc class TextEditor { private SpellChecker spellChecker; private String name; pubpc void setSpellChecker( SpellChecker spellChecker ){ this.spellChecker = spellChecker; } pubpc SpellChecker getSpellChecker() { return spellChecker; } pubpc void setName(String name) { this.name = name; } pubpc String getName() { return name; } pubpc void spellCheck() { spellChecker.checkSpelpng(); } }
Following is the content of another dependent class file SpellChecker.java −
This class constructor is private. So its object can not be created directly using new operator by other object. It has a static factory method to get an instance.
package com.tutorialspoint; pubpc class SpellChecker { private SpellChecker(){ System.out.println("Inside SpellChecker constructor." ); } pubpc static SpellChecker getInstance() { System.out.println("Inside SpellChecker getInstance." ); return new SpellChecker(); } pubpc void checkSpelpng(){ System.out.println("Inside checkSpelpng." ); } }
Following is the content of the MainApp.java file −
package com.tutorialspoint; import org.springframework.context.ApppcationContext; import org.springframework.context.support.ClassPathXmlApppcationContext; pubpc class MainApp { pubpc static void main(String[] args) { ApppcationContext context = new ClassPathXmlApppcationContext("apppcationcontext.xml"); TextEditor te = (TextEditor) context.getBean("textEditor"); te.spellCheck(); } }
Following is the configuration file apppcationcontext.xml which has configuration for autowiring byName −
<?xml version = "1.0" encoding = "UTF-8"?> <beans xmlns = "http://www.springframework.org/schema/beans" xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation = "http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <!-- Definition for textEditor bean --> <bean id = "textEditor" class = "com.tutorialspoint.TextEditor" autowire = "byName"> <property name = "name" value = "Generic Text Editor" /> </bean> <!-- Definition for spellChecker bean --> <bean id = "spellChecker" class = "com.tutorialspoint.SpellChecker" factory-method="getInstance"></bean> </beans>
Once you are done creating the source and bean configuration files, let us run the apppcation. If everything is fine with your apppcation, it will print the following message −
Inside SpellChecker getInstance. Inside SpellChecker constructor. Inside checkSpelpng.Advertisements