如何为现有用户更改会话cookie域

Mat*_*t S 5 php cookies session

我的PHP Web应用程序目前将其会话cookie域设置为example.com.我想改成它.example.com.对于新访客,ini_set('session.cookie_domain', '.example.com')作品.对于在进行此更改之前已拥有PHPSESSID cookie的访问者,域保持旧值.如何在不要求当前用户删除其Cookie的情况下更改会话cookie上的域?

  • 我不能使用JavaScript来更新cookie,因为出于安全原因它是HTTPOnly.
  • 删除服务器上的会话不会重置整个cookie,它只会更新cookie值(保持域名相同).
  • 现代浏览器会在重新启动时保留会话,因此即使cookie在浏览器会话结束时设置为过期,浏览器会话也永远不会结束.

我能想到的唯一可能性是将cookie设置为过去过期,然后重定向以获取新的cookie.但我不知道哪些访问者的cookie域设置不正确.

Sve*_*ven 3

session_name()在开始会话之前设置一个新的。这样 cookie 的名称就会改变,并且任何旧的 cookie 都将被忽略。只有新的 cookie 才会被发送出去并为会话工作。