java - Autowiring @ConfigurationProperties POJO 时出现 NullPointerException

标签 java spring spring-boot properties

我正在尝试从 POJO 对象中的 .properties 文件映射一组属性。这是因为我想重用 @Configuration 类中的属性,而且因为我的属性文件已加密,并且我不想在配置类中以纯文本形式存储 OAuth 客户端密码。

这是 POJO:

@ConfigurationProperties(ignoreInvalidFields = false, prefix = "oauth")
public class OAuthClient {

    private Map<String, String> webapp = new LinkedHashMap<>();
    private Map<String, String> admin = new LinkedHashMap<>();

    public Map<String, String> getWebapp() {
        return webapp;
    }

    public void setWebapp(Map<String, String> webapp) {
        this.webapp = new LinkedHashMap<>(webapp);
    }

    public Map<String, String> getAdmin() {
        return admin;
    }

    public void setAdmin(Map<String, String> admin) {
        this.admin = new LinkedHashMap<>(admin);
    }
}

到目前为止,我觉得一切都很好。我在以下配置类的 bean 中公开 OAuthClient:

@Configuration
@EnableConfigurationProperties(OAuthClient.class)
@PropertySource("classpath:oauth_clients.properties")
public class OAuthClientsConfiguration {

    @Bean
    public OAuthClient oAuthClient() {
        return new OAuthClient();
    }
}

这是oauth_clients.properties 文件:

oauth.OAuthClient.webapp.id=client1
oauth.OAuthClient.webapp.secret=pass1
oauth.OAuthClient.admin.id=client2
oauth.OAuthClient.admin.secret=pass2

最后,我想使用自定义 AuthorizationServerConfigurerAdapter 中的属性,但是当从 auwotired OAuthClient 获取属性时,应用程序总是无法以 NPE 启动.

这是AuthorizationServerConfigurerAdapter:

@Configuration
@EnableAuthorizationServer
public class AuthorizationServerConfiguration extends AuthorizationServerConfigurerAdapter {

    @Autowired
    private PasswordEncoder passwordEncoder;

    @Autowired
    private OAuthClient oAuthClient;

    ...

    @Override
    public void configure(ClientDetailsServiceConfigurer clients) throws Exception {
        clients.inMemory()
                .withClient(oAuthClient.getWebapp().get("id"))
                .secret(passwordEncoder.encode(oAuthClient.getWebapp().get("secret")))
                .authorizedGrantTypes(PASSWORD_GRANT, REFRESH_TOKEN_GRANT, AUTHORIZATION_CODE_GRANT)
                .scopes(READ_SCOPE, WRITE_SCOPE)
                .autoApprove(true)
                .accessTokenValiditySeconds(60 * 60)
                .refreshTokenValiditySeconds(6 * 60 * 60)
                .and()
                .withClient(oAuthClient.getAdmin().get("id"))
                .secret(passwordEncoder.encode(oAuthClient.getAdmin().get("secret")))
                .authorizedGrantTypes(PASSWORD_GRANT, REFRESH_TOKEN_GRANT, AUTHORIZATION_CODE_GRANT)
                .scopes(READ_SCOPE, WRITE_SCOPE)
                .autoApprove(true)
                .authorities(ADMIN_AUTHORITY)
                .accessTokenValiditySeconds(60 * 30)
                .refreshTokenValiditySeconds(60 * 60);
    }

这是完整的堆栈跟踪:

[ERROR] Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:2.1.6.RELEASE:run (default-cli) on project safedrive-auth-server: An exception occurred while running. null: InvocationTargetException: Error creating bean with name 'org.springframework.security.oauth2.config.annotation.web.configuration.AuthorizationServerSecurityConfiguration': Injection of autowired dependencies failed; nested exception is java.lang.NullPointerException -> [Help 1]
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:2.1.6.RELEASE:run (default-cli) on project safedrive-auth-server: An exception occurred while running. null
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:216)
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
        at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:116)
        at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:80)
        at org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build(SingleThreadedBuilder.java:51)
        at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:120)
        at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:355)
        at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:155)
        at org.apache.maven.cli.MavenCli.execute(MavenCli.java:584)
        at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:216)
        at org.apache.maven.cli.MavenCli.main(MavenCli.java:160)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229)
        at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415)
        at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356)
Caused by: org.apache.maven.plugin.MojoExecutionException: An exception occurred while running. null
        at org.springframework.boot.maven.AbstractRunMojo$IsolatedThreadGroup.rethrowUncaughtException(AbstractRunMojo.java:511)
        at org.springframework.boot.maven.RunMojo.runWithMavenJvm(RunMojo.java:93)
        at org.springframework.boot.maven.AbstractRunMojo.run(AbstractRunMojo.java:243)
        at org.springframework.boot.maven.AbstractRunMojo.execute(AbstractRunMojo.java:198)
        at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:132)
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:208)
        ... 19 more
Caused by: java.lang.reflect.InvocationTargetException
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at org.springframework.boot.maven.AbstractRunMojo$LaunchRunner.run(AbstractRunMojo.java:542)
        at java.lang.Thread.run(Thread.java:748)
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.security.oauth2.config.annotation.web.configuration.AuthorizationServerSecurityConfiguration': Injection of autowired dependencies failed; nested exception is java.lang.NullPointerException
        at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:380)
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1411)
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:592)
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:515)
        at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:320)
        at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
        at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:318)
        at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)
        at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:845)
        at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:877)
        at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:549)
        at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:140)
        at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:742)
        at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:389)
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:311)
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:1213)
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:1202)
        at com.adrianpop.AuthServer.main(AuthServer.java:11)
        ... 6 more
Caused by: java.lang.NullPointerException
        at org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder.encode(BCryptPasswordEncoder.java:80)
        at com.adrianpop.config.AuthorizationServerConfiguration.configure(AuthorizationServerConfiguration.java:76)
        at org.springframework.security.oauth2.config.annotation.web.configuration.AuthorizationServerSecurityConfiguration.configure(AuthorizationServerSecurityConfiguration.java:58)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredMethodElement.inject(AutowiredAnnotationBeanPostProcessor.java:708)
        at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:90)
        at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:374)
        ... 23 more
[ERROR] 
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR] 
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException

这几个小时我一直在努力让它工作,这让我很紧张。我还检查了官方文档,但代码对我来说看起来不错。我知道我错过了一些简单的东西,但我不知道到底是什么。

有什么建议吗? 谢谢。

最佳答案

请尝试以下代码片段

@ConfigurationProperties(prefix = "oauth")
public class OAuthClientConfig {

    private OAuthClient OAuthClient;

    public static class OAuthClient {

        private Map<String, String> webapp = new LinkedHashMap<>();
        private Map<String, String> admin = new LinkedHashMap<>();

        public Map<String, String> getWebapp() {
            return webapp;
        }

        public void setWebapp(Map<String, String> webapp) {
            this.webapp = new LinkedHashMap<>(webapp);
        }

        public Map<String, String> getAdmin() {
            return admin;
        }

        public void setAdmin(Map<String, String> admin) {
            this.admin = new LinkedHashMap<>(admin);
        }
    }

    public OAuthClientConfig.OAuthClient getOAuthClient() {
        return OAuthClient;
    }

    public void setOAuthClient(OAuthClientConfig.OAuthClient OAuthClient) {
        this.OAuthClient = OAuthClient;
    }
}

关于java - Autowiring @ConfigurationProperties POJO 时出现 NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61189969/

相关文章:

java - Java和php5 MD5 Hash的区别

java - JDBC - 空检查关闭函数

java - Spring REST XML 服务不接受 XML 作为 "accept" header

spring-security - 升级到 springBootVersion = '1.3.3.RELEASE' 后使用 RestTemplate 出现异常

Java初始化对象设计

java - 在 Spring 应用程序中将服务层与 Web 层分离

java - 无法在 mybatis+jersey Web 应用程序上集成 spring

java - Maven 无法使用 OpenJDK 11 找到 jaxb-api,即使它存在于存储库中

java - Spring应用程序未启动

java - 使用 2 个或更多帧