springboot - spring-boot-starter-thymeleaf对没有结束符的HTML5标签解析出错
问题描述
例如下面的html5代码,在解析的时候是会出错的
<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title></title></head><body><h1>Hello World</h1></body></html>
错误是没有/这个结束符org.xml.sax.SAXParseException: 元素类型 'meta' 必须由匹配的结束标记 '</meta>' 终止。后来试着在配置里添加spring.thymeleaf.mode=LEGACYHTML5也不起作用
问题解答
回答1:需要注意的是,LEGACYHTML5需要搭配一个额外的库NekoHTML才可用。到项目根目录的build.gradle文件里这样添加它到dependencies
具体内容如下:
非严格的thymeleaf格式
你可能会发现在默认配置下,thymeleaf对.html的内容要求很严格,比如<meta charset='UTF-8' />,如果少最后的标签封闭符号/,就会报错而转到错误页。也比如你在使用Vue.js这样的库,然后有<p v-cloak></p>这样的html代码,也会被thymeleaf认为不符合要求而抛出错误。
因此,建议增加下面这段:
spring.thymeleaf.mode = LEGACYHTML5spring.thymeleaf.mode的默认值是HTML5,其实是一个很严格的检查,改为LEGACYHTML5可以得到一个可能更友好亲切的格式要求。
需要注意的是,LEGACYHTML5需要搭配一个额外的库NekoHTML才可用。到项目根目录的build.gradle文件里这样添加它到dependencies:
compile(’net.sourceforge.nekohtml:nekohtml:1.9.22’)然后运行一次Gradle刷新(有任何Gradle改动,都应该这样运行一次):
Gradle刷新
最后重启项目就可以感受到不那么严格的thymeleaf了。
参考
http://acgtofe.com/posts/2016...
回答2:难道要<meta charset='UTF-8'/>?
回答3:thymeleaf: cache: false mode: html
试试换成html
相关文章:
1. angular.js - angular内容过长展开收起效果2. docker镜像push报错3. 关于docker下的nginx压力测试4. docker - 如何修改运行中容器的配置5. java - EventBus 3.0 nullPoint异常?6. javascript - fis3使用MD5但是如何引用?7. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题8. 为什么我ping不通我的docker容器呢???9. angular.js使用$resource服务把数据存入mongodb的问题。10. javascript - innerHTML内容中存在js导入或者语句无法正常运行。
