当前位置:  开发笔记 > 编程语言 > 正文

创建名称为'defaultServletHandlerMapping的bean时出错

如何解决《创建名称为'defaultServletHandlerMapping的bean时出错》经验,为你挑选了1个好方法。

这是eclipse上的spring(具有spring安全性)+ Java + Maven应用程序。提交注册表单时遇到以下错误。随后查看我的其余文件:

HTTP Status 500 - Request processing failed; nested exception is 
org.springframework.beans.factory.BeanCreationException:
 Error creating bean with name 'defaultServletHandlerMapping' defined in class 
org.springframework.web.servlet.config.annotation.DelegatingWebMvcConfiguration: 
Bean instantiation via factory method failed; nested exception is 
org.springframework.beans.BeanInstantiationException: Failed to instantiate 
[org.springframework.web.servlet.HandlerMapping]:
 Factory method 'defaultServletHandlerMapping'
 threw exception; nested exception is java.lang.IllegalArgumentException:
 A ServletContext is required to configure default servlet handling

我的文件:

AppInit

package com.myapp.config;

import org.springframework.security.web.context.*;

public class AppInit       extends AbstractSecurityWebApplicationInitializer                    

}

MyApp配置文件:

package com.myapp.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.ComponentScan.Filter;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.FilterType;
import org.springframework.jdbc.datasource.DriverManagerDataSource;
import org.springframework.web.servlet.config.annotation.DefaultServletHandlerConfigurer;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import org.springframework.web.servlet.view.InternalResourceViewResolver;
import org.springframework.web.servlet.view.JstlView;

import com.myapp.JDBC.EmailJDBC;
import com.myapp.JDBC.LastIdJDBC;
import com.myapp.JDBC.LoginJDBC;
import com.myapp.JDBC.PersonJDBC;

@EnableWebMvc //mvc:annotation-driven
@Configuration

@ComponentScan(basePackages ={ "com.myapp" })//, excludeFilters = { 
//@Filter(type = FilterType.ANNOTATION, value = Configuration.class) })

public class myappConfig extends WebMvcConfigurerAdapter {

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/resources/**").addResourceLocations("/resources/");
    }

    @Bean
    public InternalResourceViewResolver viewResolver() {
        InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();
        viewResolver.setViewClass(JstlView.class);
        viewResolver.setPrefix("/WEB-INF/views/jsp/");
        viewResolver.setSuffix(".jsp");
        return viewResolver;
    }

    @Bean
    public DriverManagerDataSource getDatasource(){
        DriverManagerDataSource dataSource = new DriverManagerDataSource();
        dataSource.setDriverClassName("com.mysql.jdbc.Driver");
        dataSource.setPassword("1234567");
        dataSource.setUrl("jdbc:mysql://localhost:3306/myapp");
        dataSource.setUsername("root");
        return dataSource;
    }
    @Bean
    public LoginJDBC getLoginBean(){
        LoginJDBC bean = new LoginJDBC();
        bean.setDataSource(new myappConfig().getDatasource());
        return bean;
    }
    @Bean
    public PersonJDBC getPersonBean(){
        PersonJDBC bean = new PersonJDBC();
        bean.setDataSource(new myappConfig().getDatasource());
        return bean;
    }
    @Bean
    public EmailJDBC getEmailBean(){
        EmailJDBC bean = new EmailJDBC();
        bean.setDataSource(new myappConfig().getDatasource());
        return bean;
    }
    @Bean
    public LastIdJDBC getLastIdBean(){
        LastIdJDBC bean = new LastIdJDBC();
        bean.setDataSource(new myappConfig().getDatasource());
        return bean;
    }
}

WebInit文件:

package com.myapp.config;

import javax.servlet.Filter;

import org.springframework.core.annotation.Order;
import org.springframework.web.filter.HiddenHttpMethodFilter;
import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;


public class myappWebInit extends
        AbstractAnnotationConfigDispatcherServletInitializer {

    @Override
    protected Class[] getServletConfigClasses() {
        return new Class[] { myappConfig.class };
    }

    @Override
    protected String[] getServletMappings() {
        return new String[] { "/","/login", "/signuPerson","/regPerson","/regPersonSuccess" };
    }

    @Override
    protected Class[] getRootConfigClasses() {
        return new Class[] { RootConfiguration.class };
    }
    @Override
    protected Filter[] getServletFilters() {
        return new Filter[] { new HiddenHttpMethodFilter() };
    }
}

安全配置文件:

package com.myapp.config;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
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.configuration.*;
import org.springframework.security.web.csrf.CsrfTokenRepository;
import org.springframework.security.web.csrf.HttpSessionCsrfTokenRepository;

@Configuration
@EnableWebSecurity
@EnableGlobalMethodSecurity(prePostEnabled=true)
public class SecurityConfig extends WebSecurityConfigurerAdapter{
    @Autowired
    private CsrfTokenRepository csrfTokenRepository() 
    { 
        HttpSessionCsrfTokenRepository repository = new HttpSessionCsrfTokenRepository(); 
        repository.setSessionAttributeName("_csrf");
        return repository; 
    }

    @Override
    protected void configure(HttpSecurity http) throws Exception {

    http
        .csrf()
            .csrfTokenRepository(csrfTokenRepository())
            .and()
        .authorizeRequests()
            .antMatchers("/resources/**", "/signuPerson").permitAll()
            .anyRequest().authenticated()
            .and()
        .formLogin()
            .loginPage("/login")
            //.failureUrl(authenticationFailureUrl)
            .permitAll()
            .and()
        .logout()
            .permitAll();


    }
    @Autowired
    public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
        auth
            .inMemoryAuthentication()
                .withUser("user").password("password").roles("USER");
    }
}

抱歉,我投入了很多东西。我已经尝试过解决类似问题的解决方案,但是没有进行锻炼。任何提示将不胜感激。提前致谢!



1> Edwardo S..:

我在此平台上针对类似问题的解决方案的帮助下解决了该问题。

通过将以下注释放入myappconfig文件中,我排除了扫描配置过滤器的麻烦:

@EnableWebMvc 
@Configuration
@ComponentScan(
  basePackages ={ "com.myapp" }, 
  excludeFilters = { 
    @Filter(type = FilterType.ANNOTATION, value = Configuration.class)
  }
)

完成此操作后,问题仍未解决。

然后我删除@EnableWebMvc并放入myappinit文件中,问题已解决。

我的猜测是,@EnableWebMvc@ComponentScan(basePackages ={ "com.myapp" }, excludeFilters = { @Filter(type = FilterType.ANNOTATION, value = Configuration.class) })不应该在同一个配置文件。

推荐阅读
echo7111436
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有