Как включить аннотацию @Secured в весеннем приложении - PullRequest
0 голосов
/ 08 июня 2018

Я использую sprig security 4.0.4.RELEASE в моем приложении Spring 4.2.5.RELEASE.Я хочу реализовать роль безопасности на уровне метода в моем приложении, используя аннотацию @Secured. Я попытался реализовать это, добавив @EnableGlobalMethodSecurity(securedEnabled = true), но произошла ошибка.

Вот мой класс SecurityConfiguration

package com.application.security;

import com.application.security.LoginSuccessHandler;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.authentication.AuthenticationManager;
import org.springframework.security.authentication.AuthenticationTrustResolver;
import org.springframework.security.authentication.AuthenticationTrustResolverImpl;
import org.springframework.security.authentication.dao.DaoAuthenticationProvider;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.builders.WebSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.security.web.authentication.rememberme.PersistentTokenBasedRememberMeServices;
import org.springframework.security.web.authentication.rememberme.PersistentTokenRepository;


@Configuration
@EnableWebSecurity
@EnableGlobalMethodSecurity(securedEnabled = true)
public class SecurityConfiguration extends WebSecurityConfigurerAdapter {

	@Autowired
	@Qualifier("customUserDetailsService")
	UserDetailsService userDetailsService;

	@Autowired
    LoginSuccessHandler loginSuccessHandler;
	
	@Autowired
	PersistentTokenRepository tokenRepository;
	
		
	/*@Autowired
	public void configureGlobalSecurity(AuthenticationManagerBuilder auth) throws Exception {
		auth.userDetailsService(userDetailsService);
		auth.authenticationProvider(authenticationProvider());
	}*/
	
	@Bean
    @Override
    public AuthenticationManager authenticationManagerBean() throws Exception {
        return super.authenticationManagerBean();
    }
	
	@Autowired
	public void configureGlobalSecurity(AuthenticationManagerBuilder auth) throws Exception {
		auth.userDetailsService(userDetailsService);
		auth.authenticationProvider(customDaoAuthenticationProvider());
	}

	@Override
	protected void configure(HttpSecurity http) throws Exception {
		http.sessionManagement().invalidSessionUrl("/logout");
		http.authorizeRequests()
				/*.antMatchers("/").access("hasRole('USER') or hasRole('ADMIN') or hasRole('DBA')")*/
				.antMatchers("/registration").permitAll()
				.antMatchers("/exclusion").permitAll()
				.antMatchers("/landing").permitAll()
				.antMatchers("/uploadSingle").permitAll()
				.antMatchers("/uploadSingleNoFile").permitAll()
				.antMatchers("/loadHtmlTableAjax").permitAll()
				.antMatchers("/AllclaimDetails").permitAll()
				.antMatchers("/deleteclaim").permitAll()
				.antMatchers("/claimComplete").permitAll()	
				.antMatchers("/exclusionComplete").permitAll()
				.anyRequest().authenticated()
				.and()
			.formLogin().loginPage("/login").permitAll()			
				.loginProcessingUrl("/login").usernameParameter("username").passwordParameter("password")
				.successHandler(loginSuccessHandler)
				.failureUrl("/login?error=true")
				.and()
	        .logout()
	            .logoutUrl("/logout")
	            .deleteCookies("JSESSIONID")
	            .permitAll()
	            .and()
			.rememberMe().rememberMeParameter("remember-me").tokenRepository(tokenRepository).tokenValiditySeconds(86400)
			    .and()
			    .csrf()
			    .and()
			    .exceptionHandling().accessDeniedPage("/Access_Denied");
	}
	
	@Override
	public void configure(WebSecurity web) throws Exception {
	    web
	       .ignoring()
	       .antMatchers("/resources/**", "/static/**", "/css/**", "/js/**", "/images/**","/logoff");
	}
		
	@Bean
	public PasswordEncoder passwordEncoder() {
		return new BCryptPasswordEncoder();
	}

	@Bean
	public DaoAuthenticationProvider authenticationProvider() {
		DaoAuthenticationProvider authenticationProvider = new DaoAuthenticationProvider();
		authenticationProvider.setUserDetailsService(userDetailsService);
		authenticationProvider.setPasswordEncoder(passwordEncoder());
		return authenticationProvider;
	}
	
    @Bean
    CustomDaoAuthenticationProvider customDaoAuthenticationProvider() {
    	CustomDaoAuthenticationProvider customAuthenticationProvider = new CustomDaoAuthenticationProvider();
    	customAuthenticationProvider.setUserDetailsService(userDetailsService);
    	customAuthenticationProvider.setPasswordEncoder(passwordEncoder());
		return customAuthenticationProvider;
    }
    
	@Bean
	public PersistentTokenBasedRememberMeServices getPersistentTokenBasedRememberMeServices() {
		PersistentTokenBasedRememberMeServices tokenBasedservice = new PersistentTokenBasedRememberMeServices(
				"remember-me", userDetailsService, tokenRepository);
		return tokenBasedservice;
	}

	@Bean
	public AuthenticationTrustResolver getAuthenticationTrustResolver() {
		return new AuthenticationTrustResolverImpl();
	}

}

Когда я даю @EnableGlobalMethodSecurity(securedEnabled = true), приложение не запускается.Я получаю ошибку ниже.

Проблема связана с компонентом AuthenticationTrustResolver

AnnotationConfigWebApplicationContext:546 - Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'appConfig': Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration': Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'metaDataSourceAdvisor': Cannot resolve reference to bean 'methodSecurityMetadataSource' while setting constructor argument; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.security.config.annotation.method.configuration.GlobalMethodSecurityConfiguration': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire method: public void org.springframework.security.config.annotation.method.configuration.GlobalMethodSecurityConfiguration.setAuthenticationTrustResolver(org.springframework.security.authentication.AuthenticationTrustResolver); nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'securityConfiguration': 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.setTrustResolver(org.springframework.security.authentication.AuthenticationTrustResolver); nested exception is org.springframework.beans.factory.BeanCurrentlyInCreationException: Error creating bean with name 'getAuthenticationTrustResolver': Requested bean is currently in creation: Is there an unresolvable circular reference?
Может кто-нибудь сказать мне причину?

Ответы [ 2 ]

0 голосов
/ 11 июня 2018

Я решил эту проблему, обновив свою весеннюю зависимость безопасности до последней в pom.xml

Я изменил версию с

<springsecurity.version>4.0.4.RELEASE</springsecurity.version>

на

<springsecurity.version>4.2.3.RELEASE</springsecurity.version>

0 голосов
/ 08 июня 2018

Пожалуйста, создайте Initializer класс, расширяя AbstractSecurityWebApplicationInitializer.

Пожалуйста, отправьте мой ответ здесь.

Нет доступных бинов с именем springSecurityFilterChain

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...