解决SpringBoot集成Thymeleaf时,首次访问静态资源路径拼接jsessionid问题

问题描述:

在用springboot+mybatis做myblog后台管理页面时,发现首次跳转页面生成的文件内js、css、图片等资源URL后面被添加上了 ;jsessionid=… 的后缀,导致页面静态资源丢失,访问不到

html文件中

登录成功跳转index页面

img

index页面代码

img

去浏览器访问,静态资源全没

img

看一眼控制台

img

可以看到被加了个jsessionid,所以访问不到!

不过,再次刷新页面有可以拿到静态资源,路径正常!

翻看Thymeleaf有关源码文件,知道Thymeleaf调用了 HttpServletResponse 的 encodeURL 函数进行URL的重写

解决办法

在Spring Boot中,我们只需要在配置文件中添加一个配置:

server.servlet.session.tracking-modes=COOKIE

如果是yml配置文件,添加下面配置

server:
  servlet:
    session:
      tracking-modes: COOKIE

让Tomcat只能从COOKIE中获取会话信息,这样,当没有Cookie时,URL也就不会被自动添加上 ;jsessionid=… 了。

清理缓存,重新起项目,访问正常!

img

其他解决方法:

参考链接

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在Spring Boot中使用Thymeleaf模板引擎访问静态HTML的过程如下: 1. 在Spring Boot工程中创建一个静态HTML文件,例如index.html。 2. 在application.properties文件中添加以下配置: ``` spring.thymeleaf.prefix=classpath:/templates/ spring.thymeleaf.suffix=.html ``` 这个配置告诉Thymeleaf模板引擎,它应该在classpath:/templates/目录下查找HTML模板文件,后缀为.html。 3. 创建一个Controller,用于处理请求并将数据传递给模板: ```java @Controller public class HomeController { @GetMapping("/") public String home(Model model) { model.addAttribute("message", "Hello, world!"); return "index"; } } ``` 这个Controller处理根路径的GET请求,并将一个名为message的属性添加到Model中。然后,它返回index作为视图的名称。 4. 在index.html中使用Thymeleaf模板引擎来呈现message属性: ```html <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>Home</title> </head> <body> <h1 th:text="${message}"></h1> </body> </html> ``` 这个HTML文件使用Thymeleaf的th:text属性来呈现message属性。 5. 启动Spring Boot应用程序,并访问http://localhost:8080/,应该看到Hello, world!。 注意:在上述步骤中,我们将HTML文件放在了classpath:/templates/目录下,这是因为Thymeleaf默认会在这个目录下查找模板文件。如果你想将HTML文件放在其他地方,可以在application.properties文件中通过配置spring.thymeleaf.prefix属性来指定模板文件的路径

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值