Thymeleaf 异常:Exception processing template “index“: An error happened during template parsing (templ

Spring Boot 项目,在 Spring Tool Suite 4, Version: 4.4.0.RELEASE 运行没有问题,将项目中的静态资源和页面复制到 IDEA 的项目中,除了 IDE 不同,其他基本相同。

运行 IDEA 中的项目,然后访问,出现异常:

Exception processing template "index": An error happened during template parsing (template: "class path resource [templates/index.html]")

具体异常:

  1 2019-12-10 21:37:40.896 ERROR 10276 --- [nio-8081-exec-1] org.thymeleaf.TemplateEngine             : [THYMELEAF][http-nio-8081-exec-1] Exception processing template "index": An error happened during template parsing (template: "class path resource [templates/index.html]")
  2 
  3 org.thymeleaf.exceptions.TemplateInputException: An error happened during template parsing (template: "class path resource [templates/index.html]")
  4     at org.thymeleaf.templateparser.markup.AbstractMarkupTemplateParser.parse(AbstractMarkupTemplateParser.java:241)
  5     at org.thymeleaf.templateparser.markup.AbstractMarkupTemplateParser.parseStandalone(AbstractMarkupTemplateParser.java:100)
  6     at org.thymeleaf.engine.TemplateManager.parseAndProcess(TemplateManager.java:666)
  7     at org.thymeleaf.TemplateEngine.process(TemplateEngine.java:1098)
  8     at org.thymeleaf.TemplateEngine.process(TemplateEngine.java:1072)
  9     at org.thymeleaf.spring5.view.ThymeleafView.renderFragment(ThymeleafView.java:362)
 10     at org.thymeleaf.spring5.view.ThymeleafView.render(ThymeleafView.java:189)
 11     at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1373)
 12     at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1118)
 13     at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1057)
 14     at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:943)
 15     at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006)
 16     at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898)
 17     at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
 18     at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883)
 19     at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
 20     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
 21     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
 22     at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
 23     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
 24     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
 25     at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100)
 26     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
 27     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
 28     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
 29     at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93)
 30     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
 31     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
 32     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
 33     at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201)
 34     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
 35     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
 36     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
 37     at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
 38     at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
 39     at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:526)
 40     at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
 41     at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
 42     at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
 43     at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
 44     at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:367)
 45     at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
 46     at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:860)
 47     at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1591)
 48     at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
 49     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
 50     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
 51     at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
 52     at java.lang.Thread.run(Thread.java:748)
 53 Caused by: org.attoparser.ParseException: Error resolving template [_fragment], template might not exist or might not be accessible by any of the configured Template Resolvers (template: "index" - line 3, col 11)
 54     at org.attoparser.MarkupParser.parseDocument(MarkupParser.java:393)
 55     at org.attoparser.MarkupParser.parse(MarkupParser.java:257)
 56     at org.thymeleaf.templateparser.markup.AbstractMarkupTemplateParser.parse(AbstractMarkupTemplateParser.java:230)
 57     ... 48 common frames omitted
 58 Caused by: org.thymeleaf.exceptions.TemplateInputException: Error resolving template [_fragment], template might not exist or might not be accessible by any of the configured Template Resolvers (template: "index" - line 3, col 11)
 59     at org.thymeleaf.engine.TemplateManager.resolveTemplate(TemplateManager.java:869)
 60     at org.thymeleaf.engine.TemplateManager.parseStandalone(TemplateManager.java:250)
 61     at org.thymeleaf.standard.expression.FragmentExpression.resolveExecutedFragmentExpression(FragmentExpression.java:588)
 62     at org.thymeleaf.standard.processor.AbstractStandardFragmentInsertionTagProcessor.computeFragment(AbstractStandardFragmentInsertionTagProcessor.java:379)
 63     at org.thymeleaf.standard.processor.AbstractStandardFragmentInsertionTagProcessor.doProcess(AbstractStandardFragmentInsertionTagProcessor.java:110)
 64     at org.thymeleaf.processor.element.AbstractAttributeTagProcessor.doProcess(AbstractAttributeTagProcessor.java:74)
 65     at org.thymeleaf.processor.element.AbstractElementTagProcessor.process(AbstractElementTagProcessor.java:95)
 66     at org.thymeleaf.util.ProcessorConfigurationUtils$ElementTagProcessorWrapper.process(ProcessorConfigurationUtils.java:633)
 67     at org.thymeleaf.engine.ProcessorTemplateHandler.handleOpenElement(ProcessorTemplateHandler.java:1314)
 68     at org.thymeleaf.engine.TemplateHandlerAdapterMarkupHandler.handleOpenElementEnd(TemplateHandlerAdapterMarkupHandler.java:304)
 69     at org.thymeleaf.templateparser.markup.InlinedOutputExpressionMarkupHandler$InlineMarkupAdapterPreProcessorHandler.handleOpenElementEnd(InlinedOutputExpressionMarkupHandler.java:278)
 70     at org.thymeleaf.standard.inline.OutputExpressionInlinePreProcessorHandler.handleOpenElementEnd(OutputExpressionInlinePreProcessorHandler.java:186)
 71     at org.thymeleaf.templateparser.markup.InlinedOutputExpressionMarkupHandler.handleOpenElementEnd(InlinedOutputExpressionMarkupHandler.java:124)
 72     at org.attoparser.HtmlElement.handleOpenElementEnd(HtmlElement.java:109)
 73     at org.attoparser.HtmlMarkupHandler.handleOpenElementEnd(HtmlMarkupHandler.java:297)
 74     at org.attoparser.MarkupEventProcessorHandler.handleOpenElementEnd(MarkupEventProcessorHandler.java:402)
 75     at org.attoparser.ParsingElementMarkupUtil.parseOpenElement(ParsingElementMarkupUtil.java:159)
 76     at org.attoparser.MarkupParser.parseBuffer(MarkupParser.java:710)
 77     at org.attoparser.MarkupParser.parseDocument(MarkupParser.java:301)
 78     ... 50 common frames omitted
 79 
 80 2019-12-10 21:37:40.900 ERROR 10276 --- [nio-8081-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.thymeleaf.exceptions.TemplateInputException: An error happened during template parsing (template: "class path resource [templates/index.html]")] with root cause
 81 
 82 org.thymeleaf.exceptions.TemplateInputException: Error resolving template [_fragment], template might not exist or might not be accessible by any of the configured Template Resolvers (template: "index" - line 3, col 11)
 83     at org.thymeleaf.engine.TemplateManager.resolveTemplate(TemplateManager.java:869)
 84     at org.thymeleaf.engine.TemplateManager.parseStandalone(TemplateManager.java:250)
 85     at org.thymeleaf.standard.expression.FragmentExpression.resolveExecutedFragmentExpression(FragmentExpression.java:588)
 86     at org.thymeleaf.standard.processor.AbstractStandardFragmentInsertionTagProcessor.computeFragment(AbstractStandardFragmentInsertionTagProcessor.java:379)
 87     at org.thymeleaf.standard.processor.AbstractStandardFragmentInsertionTagProcessor.doProcess(AbstractStandardFragmentInsertionTagProcessor.java:110)
 88     at org.thymeleaf.processor.element.AbstractAttributeTagProcessor.doProcess(AbstractAttributeTagProcessor.java:74)
 89     at org.thymeleaf.processor.element.AbstractElementTagProcessor.process(AbstractElementTagProcessor.java:95)
 90     at org.thymeleaf.util.ProcessorConfigurationUtils$ElementTagProcessorWrapper.process(ProcessorConfigurationUtils.java:633)
 91     at org.thymeleaf.engine.ProcessorTemplateHandler.handleOpenElement(ProcessorTemplateHandler.java:1314)
 92     at org.thymeleaf.engine.TemplateHandlerAdapterMarkupHandler.handleOpenElementEnd(TemplateHandlerAdapterMarkupHandler.java:304)
 93     at org.thymeleaf.templateparser.markup.InlinedOutputExpressionMarkupHandler$InlineMarkupAdapterPreProcessorHandler.handleOpenElementEnd(InlinedOutputExpressionMarkupHandler.java:278)
 94     at org.thymeleaf.standard.inline.OutputExpressionInlinePreProcessorHandler.handleOpenElementEnd(OutputExpressionInlinePreProcessorHandler.java:186)
 95     at org.thymeleaf.templateparser.markup.InlinedOutputExpressionMarkupHandler.handleOpenElementEnd(InlinedOutputExpressionMarkupHandler.java:124)
 96     at org.attoparser.HtmlElement.handleOpenElementEnd(HtmlElement.java:109)
 97     at org.attoparser.HtmlMarkupHandler.handleOpenElementEnd(HtmlMarkupHandler.java:297)
 98     at org.attoparser.MarkupEventProcessorHandler.handleOpenElementEnd(MarkupEventProcessorHandler.java:402)
 99     at org.attoparser.ParsingElementMarkupUtil.parseOpenElement(ParsingElementMarkupUtil.java:159)
100     at org.attoparser.MarkupParser.parseBuffer(MarkupParser.java:710)
101     at org.attoparser.MarkupParser.parseDocument(MarkupParser.java:301)
102     at org.attoparser.MarkupParser.parse(MarkupParser.java:257)
103     at org.thymeleaf.templateparser.markup.AbstractMarkupTemplateParser.parse(AbstractMarkupTemplateParser.java:230)
104     at org.thymeleaf.templateparser.markup.AbstractMarkupTemplateParser.parseStandalone(AbstractMarkupTemplateParser.java:100)
105     at org.thymeleaf.engine.TemplateManager.parseAndProcess(TemplateManager.java:666)
106     at org.thymeleaf.TemplateEngine.process(TemplateEngine.java:1098)
107     at org.thymeleaf.TemplateEngine.process(TemplateEngine.java:1072)
108     at org.thymeleaf.spring5.view.ThymeleafView.renderFragment(ThymeleafView.java:362)
109     at org.thymeleaf.spring5.view.ThymeleafView.render(ThymeleafView.java:189)
110     at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1373)
111     at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1118)
112     at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1057)
113     at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:943)
114     at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006)
115     at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898)
116     at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
117     at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883)
118     at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
119     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
120     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
121     at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
122     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
123     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
124     at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100)
125     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
126     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
127     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
128     at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93)
129     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
130     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
131     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
132     at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201)
133     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
134     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
135     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
136     at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
137     at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
138     at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:526)
139     at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
140     at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
141     at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
142     at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
143     at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:367)
144     at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
145     at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:860)
146     at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1591)
147     at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
148     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
149     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
150     at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
151     at java.lang.Thread.run(Thread.java:748)


起初是直接运行项目,即 Shift + F10:

后来重新编译项目,再访问,就没有出现异常:


————————————————
版权声明:本文为CSDN博主「好好活着,不要熬夜」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_29761395/article/details/120148468

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 看到你遇到了一个模板解析异常(org.thymeleaf.exceptions.TemplateInputException)的错误。 这个错误通常发生在Thymeleaf模板引擎在解析模板文件时出现问题时。可能的原因包括模板语法错误、模板文件路径错误、模板文件不存在或不可读、模板文件编码错误等等。 为了解决这个问题,你可以尝试以下几个步骤: 1. 检查模板文件路径是否正确,并确保模板文件存在和可读。你可以使用绝对路径或相对路径来引用模板文件。如果使用相对路径,请确保它相对于应用程序的根目录。 2. 检查模板文件的编码是否正确。如果模板文件的编码不正确,可能会导致解析错误。通常情况下,UTF-8编码是一个比较好的选择。 3. 检查模板语法是否正确。确保你使用的是正确的Thymeleaf语法,并且所有的标签都被正确地关闭。 如果你仍然无法解决这个问题,你可以在你的代码中设置调试标志,以便在运行时输出更详细的错误信息,帮助你更好地定位问题。 ### 回答2: org.thymeleaf.exceptions.TemplateInputException: 模板解析过程中发生错误 在使用Thymeleaf时,有时会发生模板解析失败的情况,此时会抛出TemplateInputException异常。这个异常通常是由模板语法错误或者模板文件缺失等导致的。 其主要的原因有以下几点: 1. 模板语法错误:当模板中存在语法错误,例如语法不正确、标签闭合不正确等,就会导致模板解析失败,并抛出异常。 2. 模板文件缺失:当请求某个模板文件时,如果该文件不存在,就会抛出TemplateInputException异常。 3. 模板文件编码问题:当模板文件采用非UTF-8编码方式时,可能会导致乱码或解析失败。 为了解决这个问题,我们可以逐步排查错误原因。 首先,可以检查模板文件的语法是否正确,是否存在标签未闭合等语法错误;其次,可以检查模板文件是否存在,以及路径是否正确;最后,可以检查模板文件的编码方式,确保采用UTF-8编码方式。 除此之外,还可以在模板中添加debug信息来排查问题: ``` <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>Template</title> </head> <body> <div th:text="${debug}"></div> </body> </html> ``` 通过在模板中添加debug信息,可以查看当前模板中的变量、表达式等信息,帮助排查错误。 总之,在使用Thymeleaf时,需要注意模板的语法正确性、文件是否存在、编码方式是否正确等,从而确保模板解析成功,避免出现TemplateInputException异常。 ### 回答3: org.thymeleaf.exceptions.TemplateInputException是指在解析模板过程中出现了错误,可能是由于模板文件的格式不正确或存在语法错误导致的。 模板文件通常是由HTML标记和Thymeleaf模板引擎的特定语法组成,用于动态生成Web页面。当解析模板时,Thymeleaf引擎会查找并读取模板文件,将其中的语法转换为有效的HTML标记。如果模板文件存在语法错误或无法识别,就会抛出TemplateInputException这个异常。 为了防止这种异常出现,我们要遵循以下几条规则: 1. 模板文件应该遵循HTML标准,并使用合法的语法和标记。 2. 在Thymeleaf模板文件中使用特定的语法和标记时,应该遵循Thymeleaf的规则和示例,并确认语法的正确性。 3. 对于模板文件中出现的错误,应该及时检查并修改,以免影响页面的正常输出。 4. 在开发过程中,建议在IDE中启用模板文件的语法检查器,以及及时查看和调试错误信息,避免出错。 总之,遵循标准和规则,保持良好的开发习惯,会有助于避免出现TemplateInputException这种异常,提高Web应用的稳定性和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值