0

0

Web.xml session-config cookie-config配置 Session Cookie设置

畫卷琴夢

畫卷琴夢

发布时间:2026-02-27 01:35:06

|

172人浏览过

|

来源于php中文网

原创

cookie-config 仅对新创建会话生效,不影响已有 cookie;需清理浏览器 cookie 或用隐身窗口验证,且须确保反向代理正确传递协议头、前端请求携带 credentials、domain/samesite 配置合法。

web.xml session-config cookie-config配置 session cookie设置

session-config 中 cookie-config 不生效的常见原因

直接说结论:cookie-config 配置只在容器创建新会话(即调用 request.getSession() 且 session 不存在时)才写入 Cookie 响应头;如果会话已存在、或客户端已携带旧 JSESSIONID,容器不会重发 Cookie,配置自然“看起来没用”。

典型现象:改了 http-onlysecure,但浏览器里旧 Cookie 还是没标记;或者本地开发设了 max-age,但关掉浏览器再打开,会话仍存在——其实是浏览器复用了内存中未过期的 Cookie,不是服务端没配对。

  • cookie-config 不影响已有 Cookie,只控制新发的响应头
  • 必须配合客户端清理(比如清空浏览器 Cookie 或用隐身窗口验证)才能观察效果
  • 若应用前端用 XMLHttpRequestfetch 且未设 credentials: 'include',Cookie 根本不会被带上,此时服务端配置再全也没意义

secure 和 http-only 在不同部署环境下的行为差异

secure="true" 并不等于“只在 HTTPS 下生效”,而是要求容器只在响应协议为 HTTPS 时才发送该 Cookie;但如果反向代理(如 Nginx)终止 SSL,而 Tomcat 收到的是 HTTP 请求,它就认为不安全,不会加 Secure 标志——即使用户实际走的是 HTTPS。

同理,http-only="true" 是防止 JS 读取 document.cookie,但它对拦截网络请求、调试工具、或服务端 Session 劫持无防护能力。

  • 反向代理场景下,需在 web.xml 外额外配置 Tomcat 的 RemoteIpValve,让容器识别真实协议头(如 X-Forwarded-Proto
  • http-only 开启后,前端 axiosfetch 仍可自动携带 Cookie,但 document.cookie 读不到值,调试时别误以为“Cookie 没传”
  • 某些老版本 IE 对 http-only 支持不一致,但现代主流浏览器均无问题

session-timeout 设置后,Cookie max-age 为什么没同步更新

session-config 里的 session-timeout 控制服务端 Session 对象的失效时间(单位分钟),而 cookie-config 中的 max-age 控制浏览器端 Cookie 的存活秒数——两者完全独立。不显式配置 max-age,容器默认发的是「会话级 Cookie」(即浏览器关闭即失效),和 session-timeout 无关。

百度AI搜
百度AI搜

百度全新AI搜索引擎

下载

例如:设了 session-timeout 为 30 分钟,但没设 max-age,用户关掉浏览器再打开,Session 就丢了;而如果设了 max-age="1800",Cookie 会在 30 分钟后自动删除,哪怕浏览器一直开着。

  • 要实现“服务端 30 分钟过期 + 浏览器 30 分钟自动删 Cookie”,必须同时配 session-timeoutcookie-config/max-age
  • max-age 值为负数(如 -1)表示会话 Cookie(默认行为),设为 0 表示立即删除(常用于登出逻辑)
  • 注意单位:session-timeout 是分钟,max-age 是秒

Tomcat 9+ 对 cookie-config 的兼容性限制

Tomcat 9 默认启用严格 Cookie 处理(RFC 6265),如果 cookie-config 中设置了 domain 但值不合法(比如带协议、含下划线、或非一级域名),整个 Cookie 可能被浏览器拒绝,导致会话无法维持。

更隐蔽的问题是:Tomcat 9.0.31+ 后,若未显式声明 same-site,容器不会自动补默认值,而现代浏览器(Chrome 80+)会对缺失 SameSite 的 Cookie 应用 Lax 策略——这可能导致跨站表单提交或 iframe 内嵌时丢失会话。

  • Domain 值必须以点开头(如 .example.com),且不能是 IP 或 localhost
  • 如需跨子域共享 Session,务必确认域名格式合法,并测试各浏览器表现
  • Tomcat 10+ 支持 same-site 属性,但低版本需靠过滤器或响应头手动设置

真正容易被忽略的,是 Cookie 生命周期由三段独立逻辑共同决定:服务端 Session 对象存活时间、响应 Cookie 的 Max-Age 或会话属性、以及浏览器自身策略(比如 Chrome 的第三方 Cookie 限制)。配错其中一环,问题就可能出现在你看不见的地方。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能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服务器。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

171

2024.02.23

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

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

98

2024.02.23

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

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

169

2024.02.23

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

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

156

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、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

243

2024.02.23

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

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

167

2024.02.23

Golang 实际项目案例:从需求到上线
Golang 实际项目案例:从需求到上线

《Golang 实际项目案例:从需求到上线》以真实业务场景为主线,完整覆盖需求分析、架构设计、模块拆分、编码实现、性能优化与部署上线全过程,强调工程规范与实践决策,帮助开发者打通从技术实现到系统交付的关键路径,提升独立完成 Go 项目的综合能力。

1

2026.02.26

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
php注册登录系统开发实战
php注册登录系统开发实战

共10课时 | 13.5万人学习

PHP基于Cookie的购物车模块设计
PHP基于Cookie的购物车模块设计

共10课时 | 10.8万人学习

第三期培训_PHP开发
第三期培训_PHP开发

共116课时 | 27万人学习

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

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