- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的经典 ASP 应用程序中,当客户端关闭浏览器时,与 ASP session ID 相关的 cookie 就会丢失,即使 session 没有超时。所以...
如何使 ASP session ID cookie 在客户端关闭浏览器时保持不变?
最佳答案
当您启动新的浏览器 session 并浏览到您的站点时,经典 ASP 将检测到没有 ASP session cookie,并将为您创建一个新 session (正如您已经经历过的那样)。
session cookie 就是这样,它们在 session 的生命周期内存在。当您关闭浏览器时, session cookie 将被删除(即使您在服务器上的 session 状态将作为孤立 session 继续存在,直到 Session.Timeout 过期 - 除非您在 Session.Timeout 期间再次提供相同的 session cookie)。
在新的浏览器 session /实例中延长 ASP session cookie 生命周期的唯一方法是使用浏览器/客户端上的脚本更改 cookie 生命周期。
如果您希望跨事件(例如浏览器关闭)管理状态,则需要实现自己的状态管理机制(例如将状态保存到数据库)并使用具有较长生命周期的常规 cookie(或滑动过期,您可以将服务器端脚本中每个请求的生命周期延长一小部分)以将状态与用户匹配。
编辑:
以下文章有一个修改 session cookie 的脚本(向下滚动到 Cookie 过期):
但正如 Shoban 正确指出的那样,存在 Session Fixation (OWASP) 的风险。不过,您可以采取一些措施来保护自己免受这种情况的影响:
我还要添加一些警告,如果您的应用程序正在存储敏感数据(信用卡、财务、医疗等),那么我建议不要这样做,并接受您的用户将不得不再次登录并开始的事实一个新的 session 。安全总比后悔好。
关于session - 经典 ASP session ID Cookie 生命周期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1017493/
我正在开发一个使用多个 turtle 的滚动游戏。玩家 turtle 根据按键命令在 Y 轴上移动。当危害和好处在 X 轴上移动时,然后循环并改变 Y 轴位置。我尝试定义一个名为 colliding(
我不明白为什么他们不接受这个作为解决方案,他们说这是一个错误的答案:- #include int main(void) { int val=0; printf("Input:- \n
我正在使用基于表单的身份验证。 我有一个注销链接,如下所示: 以及对应的注销方法: public String logout() { FacesContext.getCurren
在 IIS7 应用程序池中有一个设置 Idle-time out 默认是 20 分钟,其中说: Amount of time(in minutes) a worker process will rem
我是一名优秀的程序员,十分优秀!