2016-11-25 44 views
3

问候。休息控制器上的春季启动Thymeleaf ViewResolver

我有一个Spring Boot应用程序(v.1.4.1)。 先前从

<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-thymeleaf</artifactId> 
</dependency> 
<dependency> 
    <groupId>net.sourceforge.nekohtml</groupId> 
    <artifactId>nekohtml</artifactId> 
    <version>1.9.22</version> 
</dependency> 

nekohtml建立Thymeleaf - 支持thymeleaf模板不严格的HTML。 我仅将Thymeleaf模板用于电子邮件模板。该应用程序代表REST API,所有控制器返回json数据。

但是我设置了Thymeleaf的电子邮件后,一些请求正在为他们寻找Thymeleaf模板并返回code 500

Thymeleaf配置(YML,这是所有配置为thymeleaf,没有其他的JAVA CONFIGS,春季启动处理一切):

thymeleaf: 
    check-template-location: true 
    prefix: classpath:/templates/ 
    suffix: .html 
    mode: LEGACYHTML5 
    encoding: UTF-8 
    content-type: text/html 
    cache: true 

例如控制器和错误:

@RequestMapping(value = "/register", method = RequestMethod.POST) 
public JsonResponse AddUser(@RequestBody @Valid User user, WebRequest request) throws SQLException { 
    String result = userService.RegisterUser(user); 
    if(result.equals("done")) { 
     try { 
      eventPublisher.publishEvent(new OnRegistrationCompleteEvent(user, request.getLocale())); 
     } catch (Exception me) { 
      return new JsonResponse("FAIL", "Unknown on event publishing: "+ me.getMessage()); 
     } 
     return new JsonResponse("OK", ""); 

    } else if(result.equals("duplicate")) { 
     return new JsonResponse("FAIL", "duplicate"); 
    } 
    return new JsonResponse("FAIL", "Unknown"); 
} 

错误:

2016-11-25 11:02:04.285 DEBUG 15552 --- [nio-8080-exec-1] o.s.s.w.a.i.FilterSecurityInterceptor : Authorization successful 
2016-11-25 11:02:04.285 DEBUG 15552 --- [nio-8080-exec-1] o.s.s.w.a.i.FilterSecurityInterceptor : RunAsManager did not change Authentication object 
2016-11-25 11:02:04.285 DEBUG 15552 --- [nio-8080-exec-1] o.s.security.web.FilterChainProxy  : /register reached end of additional filter chain; proceeding with original chain 
2016-11-25 11:02:04.289 DEBUG 15552 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet  : DispatcherServlet with name 'dispatcherServlet' processing POST request for [/api/register] 
2016-11-25 11:02:04.291 DEBUG 15552 --- [nio-8080-exec-1] s.w.s.m.m.a.RequestMappingHandlerMapping : Looking up handler method for path /register 
2016-11-25 11:02:04.294 DEBUG 15552 --- [nio-8080-exec-1] s.w.s.m.m.a.RequestMappingHandlerMapping : Returning handler method [public com.springapp.models.common.JsonResponse com.springapp.controllers.api.IndexController.AddUser(com.springapp.models.common.User,org.springframework.web.context.request.WebRequest) throws java.sql.SQLException] 
2016-11-25 11:02:04.329 DEBUG 15552 --- [nio-8080-exec-1] m.m.a.RequestResponseBodyMethodProcessor : Read [class com.springapp.models.common.User] as "application/json;charset=UTF-8" with [org.springfr[email protected]682ef707] 
2016-11-25 11:02:15.620 DEBUG 15552 --- [nio-8080-exec-1] o.s.w.servlet.view.BeanNameViewResolver : No matching bean found for view name 'register' 
2016-11-25 11:02:15.635 DEBUG 15552 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet  : Rendering view [[email protected]] in DispatcherServlet with name 'dispatcherServlet' 
2016-11-25 11:02:15.647 ERROR 15552 --- [nio-8080-exec-1] org.thymeleaf.TemplateEngine    : [THYMELEAF][http-nio-8080-exec-1] Exception processing template "register": Error resolving template "register", template might not exist or might not be accessible by any of the configured Template Resolvers 
2016-11-25 11:02:15.651 DEBUG 15552 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet  : Error rendering view [[email protected]] in DispatcherServlet with name 'dispatcherServlet' 

org.thymeleaf.exceptions.TemplateInputException: Error resolving template "register", template might not exist or might not be accessible by any of the configured Template Resolvers 
+0

要小心 - 前缀:classpath:/ templates/- 设置前缀并将模板放在/ WEB-INF /模板中,因为如果thymeleaf配置为使用ClassLoaderTemplateResolver,那么它将搜索jar中的模板。 – Zildyan

回答

2

对不起大家,那是我的错。之前我将应用程序从Spring MVC迁移到Spring Boot,并将其分解为REST API和前端。 特别是该控制器未注明为@RestController。固定。

+0

我做了完全相同的事情,并以相同的方式修复它。 – pauli