When I use security.basic.enabled=false to disable security on a Spring Boot project that has the following dependencies:
I see the following Exception: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.boot.actuate.autoconfigure.ManagementSecurityAutoConfiguration$ManagementWebSecurityConfigurerAdapter': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire method: public void org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter.setObjectPostProcessor(org.springframework.security.config.annotation.ObjectPostProcessor); nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [org.springframework.security.config.annotation.ObjectPostProcessor] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {} In order to fix this exception I had to add the property - management.security.enabled=false . My understanding is that when the actuator is in the classpath, both security.basic.enabled=false and management.security.enabled=false should be set to disable the security. Could someone please let me know if my understanding is wrong? | |||
|
4 Answers
33 | In case you have spring-boot-actuator in your package, you should add the following @EnableAutoConfiguration(exclude = { org.springframework.boot.autoconfigure.security.SecurityAutoConfiguration.class, org.springframework.boot.actuate.autoconfigure.ManagementWebSecurityAutoConfiguration.class}) With older Spring-boot, the class was called | ||||||||
|
19 | What also seems to work fine is creating a file security.basic.enabled=falsemanagement.security.enabled=false If you then start your Spring Boot app with the | ||
|
18 | If you need security as a dependency but don't want Spring Boot to configure it for you, you can use this exclusion: @EnableAutoConfiguration(exclude = { org.springframework.boot.autoconfigure.security.SecurityAutoConfiguration.class }) | ||||
|
3 | In order to avoid security you can use annotations. Use this annotation on top of configure class: @EnableWebSecurity For example: @EnableWebSecurity@Configurationpublic class AuthFilter{ // configured method } |
ClientDetails
. You'll have a transitive import of spring-security but maybe don't want basic auth in your service. – Oct 23 '15 at 15:52