0

0

Web.xml session-config tracking-mode Cookie或URL追踪Session

煙雲

煙雲

发布时间:2026-03-13 09:06:00

|

937人浏览过

|

来源于php中文网

原创

当web.xml中tracking-mode设为COOKIE时,部分请求未携带JSESSIONID,是因为浏览器禁用Cookie、跨域、iframe嵌入或SameSite策略限制;Tomcat不会自动fallback到URL重写,需显式调用encodeURL();纯URL模式不被支持,必须与COOKIE并存;前后端分离项目中URL重写基本无效,应使用Cookie+CORS或Token方案;Tomcat 10需使用Jakarta命名空间,否则tracking-mode配置静默失效。

web.xml session-config tracking-mode cookie或url追踪session

web.xml 里 tracking-mode 设为 COOKIE 时,为什么有些请求没带 JSESSIONID?

因为浏览器禁用了 Cookie,或者当前请求是跨域、iframe 嵌入、或启用了严格第三方 Cookie 策略(比如 Chrome 的 SameSite=Lax 默认行为),导致 JSESSIONID Cookie 没被发送。Tomcat 不会自动 fallback 到 URL 重写——它只按你声明的 tracking-mode 工作。

实操建议:

  • tracking-mode 设为 COOKIE 后,不会在 URL 后追加 ;jsessionid=xxx,哪怕客户端没发 Cookie
  • 若需兜底,必须显式启用 URL 重写:在 Servlet 中调用 response.encodeURL()response.encodeRedirectURL()
  • 检查浏览器 DevTools → Application → Cookies,确认 JSESSIONID 是否存在、Domain/Path 是否匹配、是否被标记为 HttpOnlySecure(后者要求 HTTPS)

tracking-mode 改成 URL 就能强制 URL 重写?

不能。Tomcat 7+ 的 tracking-mode 不支持单独设为 URL;它只接受 COOKIEURLSSL 三者组合,且 URL 必须和 COOKIE 并存,例如:

<session-config>
  <tracking-mode>COOKIE</tracking-mode>
  <tracking-mode>URL</tracking-mode>
</session-config>
否则部署会失败(报错 Invalid tracking-mode: URL)。

原因在于:纯 URL 追踪不安全、易泄露 Session ID,Tomcat 强制要求至少一种更可靠的模式(如 Cookie)作为主通道,URL 仅作降级补充。

常见错误现象:

  • 只写一个 <tracking-mode>URL</tracking-mode> → 应用启动失败,日志报 org.xml.sax.SAXParseException
  • 写了两个 tracking-mode,但没配 COOKIE → 实际仍不生效,URL 重写不会自动触发
  • 即使配置了 COOKIEURL,Servlet 代码里没调 encodeURL(),链接仍是干净的,不会带 jsessionid

Session URL 重写对前后端分离项目有没有用?

基本没用。现代前端(React/Vue)通过 fetchaxios 发请求,默认不解析、不携带 URL 中的 jsessionid 参数,服务端也默认不从 URL 提取 Session ID(除非显式调用 HttpServletRequest#getRequestedSessionId() 并验证)。

更关键的是:Spring Boot 2.6+、Tomcat 10+ 默认禁用 URL 重写提取 Session,即使你配了 URL tracking-mode,request.getSession() 也不会从 URL 解析 ID。

Joker AIx
Joker AIx

一站式AI创意生产平台,覆盖图像、视频、音频、文案全品类创作

下载

所以真实场景中:

  • 前后端分离项目应统一走 Cookie + CORS 配置(withCredentials: true),并确保后端返回 Set-Cookie 的 Domain/Path 正确
  • 如果必须无 Cookie(比如某些嵌入式终端),改用 Token(JWT)或自定义 Header 传 Session ID,别依赖 URL 重写
  • URL 追踪真正适用的场景只剩传统 JSP/Servlet 全栈页面跳转,且用户可能禁用 Cookie

Tomcat 9 和 Tomcat 10 在 tracking-mode 行为上有啥区别?

核心逻辑一致,但 Tomcat 10 因迁移到 Jakarta EE 9,所有包名和部分配置语义变了。如果你用的是 Tomcat 10+,web.xml 必须用 Jakarta 命名空间,否则 tracking-mode 根本不被识别——看起来像配置失效。

典型错误:

  • Tomcat 10 的 web.xml 还沿用 http://java.sun.com/xml/ns/javaeetracking-mode 被忽略,回退到默认 Cookie 模式,且无任何警告
  • 正确命名空间应为:https://jakarta.ee/xml/ns/jakartaee,且 version 至少为 9.1
  • Tomcat 9 下有效的配置,在 Tomcat 10 上不报错但静默失效,排查时容易误判为应用逻辑问题

复杂点就在这儿:不是行为变了,而是配置根本没加载。别急着查 Session 超时或 Cookie 设置,先看 web.xml 的 namespace 对不对。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
如何配置Tomcat环境变量
如何配置Tomcat环境变量

配置Tomcat环境变量需要在系统中添加CATALINA_HOME变量,并将Tomcat的安装路径添加到PATH变量中。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2023.10.26

idea如何集成Tomcat
idea如何集成Tomcat

idea集成Tomcat的步骤:1、添加Tomcat服务器配置;2、配置项目部署;3、运行Tomcat服务器;4、访问项目;5、注意事项;6、关闭Tomcat服务器。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2024.02.23

怎么查看Tomcat源代码
怎么查看Tomcat源代码

查看Tomcat源代码的步骤:1、下载Tomcat源代码;2、在IDEA中导入Tomcat源代码;3、查看源代码;4、理解Tomcat的工作原理;5、参与社区和贡献;6、注意事项;7、持续学习和更新;8、使用工具和插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

99

2024.02.23

常见的tomcat漏洞有哪些
常见的tomcat漏洞有哪些

常见的tomcat漏洞有:1、跨站脚本攻击;2、跨站请求伪造;3、目录遍历漏洞;4、缓冲区溢出漏洞;5、配置漏洞;6、第三方组件漏洞。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

170

2024.02.23

tomcat日志乱码怎么解决
tomcat日志乱码怎么解决

tomcat日志乱码的解决办法:1、修改tomcat的日志编码设置;2、检查ide的编码设置;3、检查操作系统的编码设置;4、使用过滤器处理日志;5、检查外部系统的编码设置;6、检查文件编码方式等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

158

2024.02.23

weblogic和tomcat有哪些区别
weblogic和tomcat有哪些区别

weblogic和tomcat的区别:1、功能;2、性能;3、规模;4、价格;5、安全性;6、配置和管理;7、社区支持;8、集成能力;9、升级和更新;10、可靠性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

200

2024.02.23

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

tomcat启动闪退怎么解决
tomcat启动闪退怎么解决

tomcat启动闪退的解决办法:1、检查java环境;2、检查环境变量配置;3、检查端口被占用;4、检查配置文件编码;5、检查启动时需要的配置文件;6、检查相关文件是否丢失;7、检查防火墙和杀毒软件设置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

169

2024.02.23

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号