|
@@ -16,26 +16,30 @@
|
|
|
package org.springframework.security.samples.mvc.config;
|
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.context.ApplicationContext;
|
|
|
import org.springframework.context.annotation.Bean;
|
|
|
import org.springframework.context.annotation.ComponentScan;
|
|
|
import org.springframework.core.Ordered;
|
|
|
import org.springframework.data.repository.support.DomainClassConverter;
|
|
|
import org.springframework.format.support.FormattingConversionService;
|
|
|
+import org.springframework.web.servlet.ViewResolver;
|
|
|
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
|
|
|
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
|
|
|
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
|
|
|
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
|
|
|
-import org.thymeleaf.extras.tiles2.dialect.TilesDialect;
|
|
|
-import org.thymeleaf.extras.tiles2.spring4.web.configurer.ThymeleafTilesConfigurer;
|
|
|
-import org.thymeleaf.extras.tiles2.spring4.web.view.ThymeleafTilesView;
|
|
|
+import org.thymeleaf.TemplateEngine;
|
|
|
import org.thymeleaf.spring4.SpringTemplateEngine;
|
|
|
+import org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver;
|
|
|
import org.thymeleaf.spring4.view.ThymeleafViewResolver;
|
|
|
-import org.thymeleaf.templateresolver.ClassLoaderTemplateResolver;
|
|
|
+import org.thymeleaf.templatemode.TemplateMode;
|
|
|
|
|
|
@EnableWebMvc
|
|
|
@ComponentScan("org.springframework.security.samples.mvc")
|
|
|
public class WebMvcConfiguration extends WebMvcConfigurerAdapter {
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private ApplicationContext applicationContext;
|
|
|
+
|
|
|
@Autowired
|
|
|
private FormattingConversionService mvcConversionService;
|
|
|
|
|
@@ -47,42 +51,34 @@ public class WebMvcConfiguration extends WebMvcConfigurerAdapter {
|
|
|
|
|
|
@Override
|
|
|
public void addResourceHandlers(ResourceHandlerRegistry registry) {
|
|
|
- registry.addResourceHandler("/resources/**")
|
|
|
- .addResourceLocations("classpath:/resources/").setCachePeriod(31556926);
|
|
|
+ registry.addResourceHandler("/resources/**").addResourceLocations("classpath:/resources/")
|
|
|
+ .setCachePeriod(31556926);
|
|
|
registry.setOrder(Ordered.HIGHEST_PRECEDENCE);
|
|
|
}
|
|
|
|
|
|
@Bean
|
|
|
- public ClassLoaderTemplateResolver templateResolver() {
|
|
|
- ClassLoaderTemplateResolver result = new ClassLoaderTemplateResolver();
|
|
|
- result.setPrefix("views/");
|
|
|
- result.setSuffix(".html");
|
|
|
- result.setTemplateMode("HTML5");
|
|
|
- return result;
|
|
|
- }
|
|
|
-
|
|
|
- @Bean
|
|
|
- public ThymeleafTilesConfigurer tilesConfigurer() {
|
|
|
- ThymeleafTilesConfigurer tilesConfigurer = new ThymeleafTilesConfigurer();
|
|
|
- tilesConfigurer.setDefinitions(new String[] { "classpath:tiles/tiles-def.xml" });
|
|
|
- return tilesConfigurer;
|
|
|
+ public ViewResolver viewResolver() {
|
|
|
+ ThymeleafViewResolver resolver = new ThymeleafViewResolver();
|
|
|
+ resolver.setTemplateEngine(templateEngine());
|
|
|
+ resolver.setCharacterEncoding("UTF-8");
|
|
|
+ return resolver;
|
|
|
}
|
|
|
|
|
|
@Bean
|
|
|
- public SpringTemplateEngine templateEngine(
|
|
|
- ClassLoaderTemplateResolver templateResolver) {
|
|
|
- SpringTemplateEngine templateEngine = new SpringTemplateEngine();
|
|
|
- templateEngine.setTemplateResolver(templateResolver);
|
|
|
- templateEngine.addDialect(new TilesDialect());
|
|
|
- return templateEngine;
|
|
|
+ public TemplateEngine templateEngine() {
|
|
|
+ SpringTemplateEngine engine = new SpringTemplateEngine();
|
|
|
+ engine.setEnableSpringELCompiler(true);
|
|
|
+ engine.setTemplateResolver(templateResolver());
|
|
|
+ return engine;
|
|
|
}
|
|
|
|
|
|
- @Bean
|
|
|
- public ThymeleafViewResolver viewResolver(SpringTemplateEngine templateEngine) {
|
|
|
- ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();
|
|
|
- viewResolver.setTemplateEngine(templateEngine);
|
|
|
- viewResolver.setViewClass(ThymeleafTilesView.class);
|
|
|
- return viewResolver;
|
|
|
+ private SpringResourceTemplateResolver templateResolver() {
|
|
|
+ SpringResourceTemplateResolver resolver = new SpringResourceTemplateResolver();
|
|
|
+ resolver.setPrefix("classpath:/views/");
|
|
|
+ resolver.setSuffix(".html");
|
|
|
+ resolver.setTemplateMode(TemplateMode.HTML);
|
|
|
+ resolver.setApplicationContext(applicationContext);
|
|
|
+ return resolver;
|
|
|
}
|
|
|
|
|
|
@Bean
|