Spring Boot, Java Config-нет сопоставления для HTTP-запроса с URI [ / ... ] в DispatcherServlet с именем "dispatcherServlet"
это была довольно распространенная проблема здесь, в stackOverflow, но ни одна из тем той же проблемы не решает мою.
у нас есть конфигурация шаблона, которая использует XML config, но теперь мы пытаемся отойти от этого и начать использовать Java config.
Итак, у меня есть новый проект с использованием Java config и Spring Boot. Мы также используем JSP и плитки 3.
проблема в том, что он не может отобразить нашу страницу входа администратора.
здесь код:
основной конфиг класс:
@SpringBootApplication
@EnableScheduling
@Import(OnAdminBeans.class)
public class AppConfig extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(AppConfig.class, args);
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(AppConfig.class);
}
}
на AppConfig.class
is является основным пакетом. Через @ComponentScan
это @SpringBootApplication
приносит, он сканирует другие конфигурации, которые находятся на mainpackage.config
, поэтому он импортирует класс конфигурации представления:
@Configuration
@EnableWebMvc
public class ViewConfig extends WebMvcConfigurerAdapter {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/adm/static/**").addResourceLocations("/adm/static/");
}
// @Override
// public void addViewControllers(ViewControllerRegistry registry) {
// registry.addViewController("/adm/login").setViewName("login-template-tiles");
// }
@Override
public void configureViewResolvers(ViewResolverRegistry registry) {
registry.viewResolver(viewResolver());
registry.viewResolver(jspViewResolver());
registry.viewResolver(tilesViewResolver());
}
@Bean
public LocaleResolver localeResolver() {
CookieLocaleResolver localeResolver = new CookieLocaleResolver();
localeResolver.setCookieName("locale");
localeResolver.setCookieMaxAge(30);
localeResolver.setDefaultLocale(new Locale("pt", "BR"));
return localeResolver;
}
@Bean
public MultipleViewResolver viewResolver() {
Map<String, ViewResolver> viewsResolvers = new HashMap<String, ViewResolver>();
viewsResolvers.put(MultipleViewResolver.ViewType.JSP.getKey(), jspViewResolver());
viewsResolvers.put(MultipleViewResolver.ViewType.TILES.getKey(), tilesViewResolver());
MultipleViewResolver viewResolver = new MultipleViewResolver();
viewResolver.setViewsResolvers(viewsResolvers);
viewResolver.setOrder(1);
return viewResolver;
}
@Bean
public InternalResourceViewResolver jspViewResolver() {
InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();
viewResolver.setPrefix("/WEB-INF/jsp/");
viewResolver.setSuffix(".jsp");
viewResolver.setViewClass(JstlView.class);
viewResolver.setOrder(2);
return viewResolver;
}
@Bean
public UrlBasedViewResolver tilesViewResolver() {
UrlBasedViewResolver viewResolver = new UrlBasedViewResolver();
viewResolver.setViewClass(TilesView.class);
viewResolver.setOrder(3);
return viewResolver;
}
@Bean
public TilesConfigurer tilesConfigurer() {
TilesConfigurer configurer = new TilesConfigurer();
configurer.setDefinitions("/WEB-INF/tile-defs/tiles-definitions.xml");
return configurer;
}
}
на LoginController.class
определено как:
@Controller
@RequestMapping(value = "/adm")
public class LoginController {
@RequestMapping(value = "/login")
public ModelAndView login() {
return new ModelAndView("login-template-tiles");
}
}
и tiles-definitions.xml
у меня есть следующее определение для login-template-tiles:
<definition name="login-template-tiles" template="/WEB-INF/jsp/adm/templates/login-template.jsp">
<put-attribute name="admin-title" value="Admin" />
<put-attribute name="content" value="/WEB-INF/jsp/adm/templates/sections/login/index.jsp" />
</definition>
обратите внимание, что оба файла существуют.
учитывая все, что the LoginController.login () называется когда я пытаюсь получить доступ к / adm / login. Но он не может найти правильный файл JSP, конечно.
возвращает 404. С включенной трассировкой я получаю следующий журнал:
DispatcherServlet with name 'dispatcherServlet' processing GET request for [/WEB-INF/jsp/adm/templates/login-template.jsp]
Testing handler map [org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping@2118c09a] in DispatcherServlet with name 'dispatcherServlet'
Looking up handler method for path /WEB-INF/jsp/adm/templates/login-template.jsp
Did not find handler method for [/WEB-INF/jsp/adm/templates/login-template.jsp]
Testing handler map [org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping@2c148974] in DispatcherServlet with name 'dispatcherServlet'
No handler mapping found for [/WEB-INF/jsp/adm/templates/login-template.jsp]
Testing handler map [org.springframework.web.servlet.handler.SimpleUrlHandlerMapping@784c3547] in DispatcherServlet with name 'dispatcherServlet'
No handler mapping found for [/WEB-INF/jsp/adm/templates/login-template.jsp]
Testing handler map [org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport$EmptyHandlerMapping@533e0604] in DispatcherServlet with name 'dispatcherServlet'
Testing handler map [org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport$EmptyHandlerMapping@cfd1b4e] in DispatcherServlet with name 'dispatcherServlet'
No mapping found for HTTP request with URI [/WEB-INF/jsp/adm/templates/login-template.jsp] in DispatcherServlet with name 'dispatcherServlet'
любые предложения!
EDIT: Ладно. Отладив, я обнаружил, что это имеет какое-то отношение к встроенному Tomcat. Кроме этого, у меня понятия не имею, что происходит.
EDIT 2:
обнаружил, что проблема в org.springframework.сеть.сервлет.DispatcherServlet#getHandler. Он просто не находит HandlerMapping для этого запроса. Должен ли я зарегистрировать его?
3 ответов
OK! Найти проблему.
эта ссылка помогла мне: https://samerabdelkafi.wordpress.com/2014/08/03/spring-mvc-full-java-based-config/
более конкретно эта конфигурация:
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();
}
установив обработчик по умолчанию, я бы больше не получал белую страницу, а вместо этого код JSP как html, который ясно говорит мне, что JSP был найден, но не отображен.
Итак, ответ был на этой странице:JSP файл не рендеринг в веб-приложении Spring Boot
Я пропустил tomcat-embed-Джаспер артефакт.
добавить зависимость ниже к вашему pom.в XML
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
<scope>provided</scope>
</dependency>
советы здесь помогли мне, когда я застрял с подобной проблемой. Я исправил его после добавления этого фрагмента в мою конфигурацию
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();
}