public class DefaultBeanDefinitionDocumentReader extends Object implements BeanDefinitionDocumentReader
BeanDefinitionDocumentReader interface that
reads bean definitions according to the "spring-beans" DTD and XSD format
(Spring's default XML bean definition format).
The structure, elements, and attribute names of the required XML document
are hard-coded in this class. (Of course a transform could be run if necessary
to produce this format). <beans> does not need to be the root
element of the XML document: this class will parse all bean definition elements
in the XML file, regardless of the actual root element.
| 限定符和类型 | 字段和说明 |
|---|---|
static String |
ALIAS_ATTRIBUTE |
static String |
ALIAS_ELEMENT |
static String |
BEAN_ELEMENT |
static String |
IMPORT_ELEMENT |
protected Log |
logger |
static String |
NAME_ATTRIBUTE |
static String |
NESTED_BEANS_ELEMENT |
static String |
PROFILE_ATTRIBUTE |
static String |
RESOURCE_ATTRIBUTE |
| 构造器和说明 |
|---|
DefaultBeanDefinitionDocumentReader() |
| 限定符和类型 | 方法和说明 |
|---|---|
protected BeanDefinitionParserDelegate |
createDelegate(XmlReaderContext readerContext,
Element root,
BeanDefinitionParserDelegate parentDelegate) |
protected void |
doRegisterBeanDefinitions(Element root)
Register each bean definition within the given root
<beans/> element. |
protected Object |
extractSource(Element ele)
Invoke the
SourceExtractor
to pull the source metadata from the supplied Element. |
protected XmlReaderContext |
getReaderContext()
Return the descriptor for the XML resource that this parser works on.
|
protected void |
importBeanDefinitionResource(Element ele)
Parse an "import" element and load the bean definitions
from the given resource into the bean factory.
|
protected void |
parseBeanDefinitions(Element root,
BeanDefinitionParserDelegate delegate)
Parse the elements at the root level in the document:
"import", "alias", "bean".
|
protected void |
postProcessXml(Element root)
Allow the XML to be extensible by processing any custom element types last,
after we finished processing the bean definitions.
|
protected void |
preProcessXml(Element root)
Allow the XML to be extensible by processing any custom element types first,
before we start to process the bean definitions.
|
protected void |
processAliasRegistration(Element ele)
Process the given alias element, registering the alias with the registry.
|
protected void |
processBeanDefinition(Element ele,
BeanDefinitionParserDelegate delegate)
Process the given bean element, parsing the bean definition
and registering it with the registry.
|
void |
registerBeanDefinitions(Document doc,
XmlReaderContext readerContext)
This implementation parses bean definitions according to the "spring-beans" XSD
(or DTD, historically).
|
protected final Log logger
public void registerBeanDefinitions(Document doc, XmlReaderContext readerContext)
Opens a DOM Document; then initializes the default settings
specified at the <beans/> level; then parses the contained bean definitions.
registerBeanDefinitions 在接口中 BeanDefinitionDocumentReaderdoc - the DOM documentreaderContext - the current context of the reader
(includes the target registry and the resource being parsed)protected final XmlReaderContext getReaderContext()
@Nullable protected Object extractSource(Element ele)
SourceExtractor
to pull the source metadata from the supplied Element.protected void doRegisterBeanDefinitions(Element root)
<beans/> element.protected BeanDefinitionParserDelegate createDelegate(XmlReaderContext readerContext, Element root, @Nullable BeanDefinitionParserDelegate parentDelegate)
protected void parseBeanDefinitions(Element root, BeanDefinitionParserDelegate delegate)
root - the DOM root element of the documentprotected void importBeanDefinitionResource(Element ele)
protected void processAliasRegistration(Element ele)
protected void processBeanDefinition(Element ele, BeanDefinitionParserDelegate delegate)
protected void preProcessXml(Element root)
The default implementation is empty. Subclasses can override this method to convert custom elements into standard Spring bean definitions, for example. Implementors have access to the parser's bean definition reader and the underlying XML resource, through the corresponding accessors.
getReaderContext()protected void postProcessXml(Element root)
The default implementation is empty. Subclasses can override this method to convert custom elements into standard Spring bean definitions, for example. Implementors have access to the parser's bean definition reader and the underlying XML resource, through the corresponding accessors.
getReaderContext()