Не найдено сопоставление для HTTP-запроса с URI с конфигурацией аннотаций Spring MVC и Jetty

Я использую конфигурацию только аннотации, сервер запускается, но когда я получаю доступ к какой-либо странице, отображается сообщение об ошибке:

ВНИМАНИЕ: Не найдено сопоставление для HTTP-запроса с URI [/WEB-INF/view/main.jsp] в DispatcherServlet с именем org.springframework.web.servlet.DispatcherServlet-d7259e.

Отображение контроллера работает нормально, но страница JSP не загружена.

Я использую Jetty 9.2.0.M0 и Spring MVC 4.0.4-RELEASE.

Конфиг Jetty:

private static final String CONTEXT_PATH = "/";
private static final String MAPPING_URL = "/*";

private void startServer(int port) throws Exception {
        Server server = new Server(port);
        server.addLifeCycleListener(new LifeCycleListener());
        server.setHandler(getServletContextHandler(getContext()));
        server.start();
        server.join();
    }

    private static ServletContextHandler getServletContextHandler(WebApplicationContext context) throws IOException {
        LOGGER.info("Preparing ServletContextHandler");
        ServletContextHandler contextHandler = new ServletContextHandler();
        contextHandler.setContextPath(CONTEXT_PATH);
        contextHandler.addServlet(new ServletHolder(new DispatcherServlet(context)), MAPPING_URL);
        contextHandler.addEventListener(new ContextLoaderListener(context));

        return contextHandler;
    }

    private static WebApplicationContext getContext() {
        LOGGER.info("Preparing annotation context");
        AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();    
        context.register(SpringMVCConfig.class);
        return context;
    }

SpringMVCConfig:

@Configuration
@ComponentScan(basePackages = "my.package.controller")
@EnableWebMvc
public class SpringMVCConfig extends WebMvcConfigurerAdapter {

    private static final Logger LOGGER = LogManager.getLogger(SpringMVCConfig.class);

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        LOGGER.info("Adding resource handlers");
        registry.addResourceHandler("/i/**").addResourceLocations("classpath:WEB-INF/images/");
        registry.addResourceHandler("/c/**").addResourceLocations("classpath:WEB-INF/css/");
        registry.addResourceHandler("/js/**").addResourceLocations("classpath:WEB-INF/javascripts/");
    }

    @Bean
    public ViewResolver prepareViewResolver() {
        LOGGER.info("Returning view resolver");
        InternalResourceViewResolver resolver = new InternalResourceViewResolver();
        resolver.setPrefix("WEB-INF/view/");
        resolver.setSuffix(".jsp");
        // resolver.setViewClass(JstlView.class);
        return resolver;
    }

}

Нет ни web.xml, ни каких-либо других XML-файлов.

main.jsp существует

Благодарю.

1 ответ

Решение

Используйте этот скелет на GitHub, это рабочий пример - https://github.com/jasonish/jetty-springmvc-thymeleaf-template

Другие вопросы по тегам