Spring's dependency injection mechanism is mainly
based on type , not names. When encountering multiple types of the same type (such as TenantDataSource), it will not automatically return to match according to the parameter name. This is because Spring cannot always guarantee the parameter name in the method to match the Bean name.
Java By default,will not retain the parameter name in the compiled bytecode. If there is no special configuration, the parameter names (for example, TenantadataSource and TenantbDataSource) will be cleared during the compilation and replaced them with universal names, such as ARG0 and ARG1. Therefore, Spring cannot know that TenanTadataSource refers to the bean called "Tenanta-Datasource".
Solve the parameter name retention problemYou can use the Compiler logo to retain the parameter name in the byte code:
-parameters
<code>javac -parameters MyClass.java</code>
Spring avoids assumptions to prevent accidents. For example, if the parameter name is accidentally exchanged or named, or the developers expect different mappings, what will happen? If there is no clear guidance (such as
), Spring cannot determine the intention of the developer, and choose to throw an error instead of injecting the wrong bean.
@Qualifier
Spring follows the principle of "explicitly better than hidden". Dependent injection should be predictable, and does not depend on the assumptions of parameter names to the matching of Bean name matching. Spring is consistent in different environments and frameworks. Some languages or frameworks (such as KOTLIN) retain the parameter name by default, while other languages are not retained. Therefore, Spring avoids dependent parameter names to achieve key functions.
When can the name match can work automatically?
Although Spring does not match the parameter name by default, it can be matched according to the parameter name in some cases, but it depends on your settings:
Spring 4.3 Parameter name Discover
If the logo compile code, when there is ambiguity, Spring can infer the name of the Bean from the parameter name.
Example:
-parameters
).
<code>@Autowired public TenantService(TenantDataSource tenantADataSource, TenantDataSource tenantBDataSource) { this.tenantADataSource = tenantADataSource; this.tenantBDataSource = tenantBDataSource; }</code>Why is Spring more inclined to use @qualifier?
-parameters
Use to ensure definition and eliminate ambiguity, so that both developers and frameworks can clearly intention. @Qualifier
In this way, Spring can accurately know which bean to inject, regardless of parameter name or other factors.
Spring should be smarter?
Some people may think that a framework like Spring should be more intelligent, and the Bean name is automatically matched with the parameter name when there is ambiguity. But:
- Back compatibility : Automatically changing this behavior may destroy the existing applications that do not match the Bean name and parameter name. predictability
- : explicitly solve the ambiguity (for example, through ) to ensure that developers always know which bean is being injected. Reacable assumptions may cause difficulty in debugging, especially in large complex applications.
@Qualifier
The situation in the real scene
In most actual applications:
Developers use meaningful bean names and parameter names, but they also prefer to prefer
- to ensure their clarity.
-
@Qualifier
For multi -example scenes, dynamically configure - or factory -based methods (eg ABSTRACTROUTINGATASORCE), instead of manually connecting each bean. Key points
Spring first injects by type
- : If there is only one type of Bean, Spring will inject it without any problems. If there are multiple beans of the same type, Spring requires additional prompts (such as
- ) to solve ambiguity.
The parameter name is not reliable.
@Qualifier
: By default, the parameter name will not be kept in the Java bytecode, so Spring cannot use them to match the parameter with the parameters. Even if the parameter name ( ) is retained, Spring will avoid the well -known matching matching, unless the configuration is clear. -
Explicit is better than hidden : Spring priority consideration can be predictable, and encourages developers to use explicit configuration (such as
-parameters
or ) instead of relying on hidden matching. -
Spring's design concept
: Misty errors can prevent accidents and ensure that developers fully control the dependence injection.@Qualifier
@Primary
The above is the detailed content of spring-: why-spring-cannot-match-by-name-for-injection. For more information, please follow other related articles on the PHP Chinese website!

Start Spring using IntelliJIDEAUltimate version...

When using MyBatis-Plus or other ORM frameworks for database operations, it is often necessary to construct query conditions based on the attribute name of the entity class. If you manually every time...

Java...

How does the Redis caching solution realize the requirements of product ranking list? During the development process, we often need to deal with the requirements of rankings, such as displaying a...

Conversion of Java Objects and Arrays: In-depth discussion of the risks and correct methods of cast type conversion Many Java beginners will encounter the conversion of an object into an array...

Solutions to convert names to numbers to implement sorting In many application scenarios, users may need to sort in groups, especially in one...

Detailed explanation of the design of SKU and SPU tables on e-commerce platforms This article will discuss the database design issues of SKU and SPU in e-commerce platforms, especially how to deal with user-defined sales...

How to set the SpringBoot project default run configuration list in Idea using IntelliJ...


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment