Home Java javaTutorial The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

Nov 23, 2024 am 07:53 AM

In this article I would like to share a problem I encountered recently, which I think may be of interest to you.

What is the issue?

The source code for both the testing and production environments is same, and both the local and testing environments run well, only the production environment run with an NPE of a service class failed to load, which added for the new requirements. This class inherits the interface from the Customize package (a self-developed toolkit).

The Project Structure

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

The design of Customize relies on Spring to manage APIs and services. With Spring automatic scanning, the common classes of ApiEnhancer and ServiceEnhancer are loaded when initializing classes, and obtain instances by ApplicationContext. Debugging found that when loading them, the ApplicationContext is null and has not been initialized yet. It is initialized in the setApplicationContext method by implementing ApplicationContextAware, so it is speculated that the setApplicationContext method has not been executed.

During the loading process of the ApplicationContextProvider class, the static methods are loaded into the Method Area during the initialization phase. However, when using the ApplicationContext to get instances of beans, the static methods are directly invoked by the class name. As long as the API is created before the ApplicationContextProvider been allocated memory in the heap and instantiated, the setApplicationContext method will not be invoked to initialize.

The applicationContextProvider uses the annotation @Component, and the Api uses the annotation @RestController, and the two classes are in the same path. However, when Spring scans and loads them, there is no specific order, which means each of both classes may be created before another. In the production environment, the Api is created before the applicationContextProvider, resulting that when the static method invoked directly by the class name to obtain beans, the applicationContext has NOT been initialized.

The solutions

If the setApplicationContext method of the implementation class of the ApplicationContextAware interface has not been executed, first check whether the implementation class has been set to lazy loading or whether the project has configured global lazy loading.

In this project, the problem was caused by the creation order of the implementation classes of the ApiEnhancer and ApplicationContextAware interfaces, and the Api class is just a regular RESTful API that handles business logic and can be loaded when invoked by the front-end page. Therefore, changing to lazy loading solved the problem.

It is advisable to minimize the dependency relationship between classes in terms of loading order. If unavoidable, lazy loading, or annotations such as @DependsOn, @Order, @Priority can be used to control the loading order of beans.


Why are the creation order of production environment and testing environment different?

Let's debug to check the scanning process of Spring.

Starting with the scan method of ClassPathBeanDeterminationScanner.

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

doScan method

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

scanCandidateComponents method of ClassPathScanningCandidateComponentProvider

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

findAllClassPathResources method of PathMatchingResourcePatternResolver

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

doFindPathMatchingJarResources method

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

JarFile is a class in the Java Standard Library under the package java.util.jar, which inherits and extends ZipFile. jarFile.entries() returns an iterator named JarEntryIterator.

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

JarExitIterator is an implementation of the Iterator Pattern, which iterates on the entries of the parent class of JarFile.

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

The entries method of ZipFile return an iterator named ZipExitIterator.

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

The nextElement method of ZipExitIterator invokes the next method, which in turn invokes the getNextEntry method.

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

getNextEntry is a native method.

The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans

The native method is implemented in non Java languages and invoked within the Java Virtual Machine to implement underlying functionality, which may vary depending on the environment (Operating System or JDK version). JAR packages themselves do not have an order, so the actual traversal order may vary depending on different JAR packaging tools and environments.

The above is the detailed content of The setApplicationContext method execution issue of the applicationContextAware interface and failed to get Spring beans. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Is the company's security software causing the application to fail to run? How to troubleshoot and solve it? Is the company's security software causing the application to fail to run? How to troubleshoot and solve it? Apr 19, 2025 pm 04:51 PM

Troubleshooting and solutions to the company's security software that causes some applications to not function properly. Many companies will deploy security software in order to ensure internal network security. ...

How to simplify field mapping issues in system docking using MapStruct? How to simplify field mapping issues in system docking using MapStruct? Apr 19, 2025 pm 06:21 PM

Field mapping processing in system docking often encounters a difficult problem when performing system docking: how to effectively map the interface fields of system A...

How to elegantly obtain entity class variable names to build database query conditions? How to elegantly obtain entity class variable names to build database query conditions? Apr 19, 2025 pm 11:42 PM

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...

How does IntelliJ IDEA identify the port number of a Spring Boot project without outputting a log? How does IntelliJ IDEA identify the port number of a Spring Boot project without outputting a log? Apr 19, 2025 pm 11:45 PM

Start Spring using IntelliJIDEAUltimate version...

How do I convert names to numbers to implement sorting and maintain consistency in groups? How do I convert names to numbers to implement sorting and maintain consistency in groups? Apr 19, 2025 pm 11:30 PM

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

How to safely convert Java objects to arrays? How to safely convert Java objects to arrays? Apr 19, 2025 pm 11:33 PM

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...

Why does the Spring project cause randomness problems due to circular dependencies when starting? Why does the Spring project cause randomness problems due to circular dependencies when starting? Apr 19, 2025 pm 11:21 PM

Understand the randomness of circular dependencies in Spring project startup. When developing Spring project, you may encounter randomness caused by circular dependencies at project startup...

How to use the Redis cache solution to efficiently realize the requirements of product ranking list? How to use the Redis cache solution to efficiently realize the requirements of product ranking list? Apr 19, 2025 pm 11:36 PM

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...

See all articles