JeeGit 官方论坛

找回密码
立即注册
搜索
热搜: 活动 交友 discuz
发新帖

1

收听

0

听众

191

主题
发表于 2023-3-7 16:32:23 | 查看: 586| 回复: 0
SpringBoot 整合视图层,freemarker、thymeleaf、jsp 三者共存问题


一、三者同时存在的情况下
访问各自页面
(1)访问 freemarker 页面成功
(2)访问 thymeleaf 页面成功
(3)访问 jsp 页面失败
二、freemarker 与 thymeleaf 共存的情况
访问各自页面
(1)访问 freemarker 页面成功
(2)访问 thymeleaf 页面成功
viewname同名的情况下,访问页面优先级
freemarker > thymeleaf
三、freemarker 与 jsp 共存的情况
访问各自页面
(1)访问 freemarker 页面成功
(2)访问 jsp 页面成功
viewname同名的情况下,访问页面优先级
freemarker > jsp
四、thymeleaf 与 jsp 共存的情况
访问各自页面
(1)访问 thymeleaf 页面成功
(2)访问 jsp 页面失败
五、结论
freemarker 与 thymeleaf 可共存,当两者视图同名时,优先访问 freemarker,因为 freemarker 优先级高于 thymeleaf
freemarker 与 jsp 可共存,当两者视图同名时,优先访问 freemarker,因为 freemarker 优先级高于 jsp
thymeleaf 与 jsp 不可共存,访问 jsp 页面直接报错,访问 thymeleaf 页面则没问题
六、thymeleaf 与 jsp 不可共存的原因
1.ThymeleafviewResolver 找不到对应的 Thymeleaf 视图后直接返回了error错误页面,于是排在后面用来解析Jsp视图的InternalResourceViewResolver就失效了

七、如何让 thymeleaf 与 jsp 共存
配置多视图解析器时,thymeleaf 要放在 /WEB-INF/html/ 路径下
原因:通过@SpringBootApplication(exclude = {ThymeleafAutoConfiguration.class})不让Spring Boot自动装载Thymeleaf模板引擎,参照网上的方法手动去装载,但发现一个很奇怪的情况,把templateResolver的前缀设置为templateResolver.setPrefix(“classpath:/templates/”);无法找到该路径下的html资源,只有设置为templateResolver.setPrefix(“/WEB-INF/views/”);才能找到对应路径下的html资源,而“/WEB-INF/views/”其实是Jsp视图的InternalResourceViewResolver中设置的前缀,仿佛是ThymeleafviewResolver自己的templateResolver前缀无效,只有和InternalResourceViewResolver的viewResolver前缀一致时才能找到对应的html资源。

问题: ThymeleafviewResolver 自己的 templateResolver 为什么会失效 ?

1.配置多视图解析器
步骤:
(1)导入 thymeleaf 与 jsp 的依赖
(2)在 WEB-INF 下新建两个文件夹储存各自的页面
(3)配置文件中导入 thymeleaf 的配置,jsp 的不用
(4)自定义一个多视图解析器
(5)编写 controller 访问请求访问各自页面
2.结论
(1) 官网文档中说:在打包为jar后,大多数构建工具不会打包webapp目录,而 spring boot 项目都是打包为jar
(2)thymeleaf 与 jsp 共存过于麻烦
所以官方不推荐使用 jsp
————————————————
版权声明:本文为CSDN博主「ヅ清世丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_43173365/article/details/127051352


您需要登录后才可以回帖 登录 | 立即注册

QQ|Archiver|手机版|小黑屋|JeeGit 官方论坛 ( 吉ICP备19001578号-2|吉B2-20200006 )

GMT+8, 2024-4-20 12:11 , Processed in 0.044982 second(s), 17 queries .

Powered by Discuz! X3.5

Copyright © 2001-2024 Tencent Cloud.

快速回复 返回顶部 返回列表