Чтобы решить эту проблему, я создал прокси для SpringTemplateEngine
и посоветовал TemplateEngine.process()
метод.
Как это работает:
код карта макеты на основе путей шаблона, например:
portal/moje_konto/moje_dane
сопоставлен макет
LAYOUTS_PATH/portal
Кроме того, она проходит переменную VIEW, содержащий путь к фактическому шаблону
Внутренние макеты могут использоваться для включения определенных фрагментов. Очень простой макет портала может выглядеть так:
<!DOCTYPE html SYSTEM "about:legacy-compat">
<html lang="pl" xmlns="http://www.w3.org/1999/xhtml" xmlns:th="http://www.thymeleaf.org" xmlns:sec="http://www.springframework.org/security/tags">
<body>
<div th:replace="${'portal/' + VIEW} :: content">Content</div>
</body>
</html>
Контроллер:
@PreAuthorize("isAuthenticated()")
@RequestMapping(value = "/", method = RequestMethod.GET)
public String home(Model model) {
return "portal/home/index";
}
TemplateEngine:
public class LayoutTemplateEngine implements ITemplateEngine, MessageSourceAware, InitializingBean {
private final Logger logger = Logger.getLogger(this.getClass().getName());
private final String LAYOUTS_PATH = "layouts/";
private final SpringTemplateEngine templateEngine = new SpringTemplateEngine();
@Override
public void process(TemplateSpec templateSpec, IContext context, Writer writer) {
String template = templateSpec.getTemplate();
logger.info("Rendering template: " + template);
if (context instanceof WebExpressionContext) {
int end = template.indexOf("/");
if (end != -1) {
// change template
templateSpec = new TemplateSpec(LAYOUTS_PATH + template.substring(0, end), templateSpec.getTemplateSelectors(), templateSpec.getTemplateMode(), templateSpec.getTemplateResolutionAttributes());
// add VIEW variable
((WebExpressionContext)context).setVariable("VIEW", template.substring(end + 1));
}
}
templateEngine.process(templateSpec, context, writer);
logger.info("Rendering finished");
}
public void setTemplateResolver(final ITemplateResolver templateResolver) {
templateEngine.setTemplateResolver(templateResolver);
}
public void setEnableSpringELCompiler(final boolean enableSpringELCompiler) {
templateEngine.setEnableSpringELCompiler(enableSpringELCompiler);
}
public void addDialect(final IDialect dialect) {
templateEngine.addDialect(dialect);
}
public void addTemplateResolver(final ITemplateResolver templateResolver) {
templateEngine.addTemplateResolver(templateResolver);
}
@Override
public IEngineConfiguration getConfiguration() {
return templateEngine.getConfiguration();
}
@Override
public String process(String template, IContext context) {
return process(new TemplateSpec(template, null, null, null), context);
}
@Override
public String process(String template, Set<String> templateSelectors, IContext context) {
return process(new TemplateSpec(template, templateSelectors, null, null), context);
}
@SuppressWarnings("resource")
@Override
public String process(TemplateSpec templateSpec, IContext context) {
final Writer stringWriter = new FastStringWriter(100);
process(templateSpec, context, stringWriter);
return stringWriter.toString();
}
@Override
public void process(String template, IContext context, Writer writer) {
process(new TemplateSpec(template, null, null, null), context, writer);
}
@Override
public void process(String template, Set<String> templateSelectors, IContext context, Writer writer) {
process(new TemplateSpec(template, templateSelectors, null, null), context, writer);
}
@Override
public IThrottledTemplateProcessor processThrottled(String template, IContext context) {
return processThrottled(new TemplateSpec(template, null, null, null), context);
}
@Override
public IThrottledTemplateProcessor processThrottled(String template, Set<String> templateSelectors, IContext context) {
return processThrottled(new TemplateSpec(template, templateSelectors, null, null), context);
}
@Override
public IThrottledTemplateProcessor processThrottled(TemplateSpec templateSpec, IContext context) {
return templateEngine.processThrottled(templateSpec, context);
}
@Override
public void afterPropertiesSet() throws Exception {
templateEngine.afterPropertiesSet();
}
@Override
public void setMessageSource(MessageSource messageSource) {
templateEngine.setMessageSource(messageSource);
}
}
любые решения нашли? –
Я опубликовал решение в качестве принятого ответа. Надеюсь, поможет. –