微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

用户帐户的PHP cookie和会话安全性

在研究了使用“记住我”功能进行安全登录方法之后,我遇到了许多关于如何使其安全的相互矛盾的观点.我希望创建的登录系统不需要高度安全,但我想选择一个安全简便的方法,我有两个问题.

>应该存储在会话变量中以检查用户是否已登录,这只是用户名(或ID).如果它只是用户名,那么在用户发现他们的帐户遭到入侵并希望更改密码以阻止恶意用户搞乱其帐户的情况下会发生什么?如果恶意用户有会话,那么即使密码被更改,他们仍然可以继续恶意,直到他们的会话到期为止,这是否可以避免 – 可能使密码更改时使用该用户名的所有会话无效?
>在(HttpOnly)cookie中存储密码(使用仅用于cookie的盐重新加密)和用户名是否具有“记住我”功能的足够方式?我听说过数据库存储用户名随机生成的密钥的方法,这也放在用户cookie中.然后,当用户操作发生时,旧密钥被替换为新密钥并被提供给用户的cookie.这种类型的cookie安全性是否值得,或者通常的重新加密密码方法是否足够?

解决方法:

通常,如果你想记住用户,你会生成一个“密钥”并将其存储在数据库中,然后设置它的“生命周期”(这可以是任何东西,比如6小时或2天).您将该密钥存储在cookie中(以及用户ID).现在,每次用户连接到网站时,您都会比较两个密钥.如果数据库中的密钥已超过其生命周期,则生成新密钥并将其存储在cookie中.因此,如果某人窃取了cookie(不知何故),他必须在再次连接到网站并重置密钥之前使用它.这是我最常见的方法.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐