首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >实现“记住我”特性

实现“记住我”特性
EN

Stack Overflow用户
提问于 2012-08-12 10:30:47
回答 2查看 459关注 0票数 0

基本上,我有一个具有基本会话功能的登录系统,它在浏览器关闭时超时。我一直收到关于这方面的投诉,所以我希望能够让一些人点击“记住”,并让他们的会话持续30天。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-08-12 10:34:25

例如,在设置$_SESSION['user_id']的同时设置cookie。如下所示:

代码语言:javascript
复制
$token = hash('md5',$_SESSION['user_id'] . time() . 'salt');
setcookie('token', $token, time() + (3600 * 24 * 30));
setcookie('user_id', $_SESSION['user_id'], time() + (3600 * 24 * 30)); // Cookie expires in 30 days

$token保存在数据库中的user_id行中。

然后为保存了cookies的用户设置$_SESSION['user_id'],这样他们就不必以正常方式登录:

代码语言:javascript
复制
if (!isset($_SESSION['user_id']) {

    if (isset($_COOKIE['user_id']) && isset($_COOKIE['token']) {

       $saved_token = SELECT token FROM users table WHERE userID = $_COOKIE['user_id'];
         if ($_COOKIE['token'] == $saved_token) { 
         $_SESSION['user_id'] = $_COOKIE['user_id'];
       } else log out
       }
}  else log out
}
}

也许这在安全性方面效果更好呢?

票数 -1
EN

Stack Overflow用户

发布于 2012-08-12 10:52:05

如上所述,这可以通过cookie来完成。虽然有很多tutorials,但对于安全性来说,一个好的方法是必要的。我还记得,在Orkut,一个已经消亡很久的社交网站,你可以让用户运行一些脚本,窃取他的cookies和viola,即使用户已经注销,帐户也是你的。

所以这里是一个最好的方法。

  • 在用户上创建一个cookie,用一些盐hashing用户id,称之为用户令牌。
  • 在您的数据库中存储令牌和它所属的用户及其过期日期。
  • 现在,当用户使用其cookie访问时,只需检查哈希是否在数据库中,并将访问者登录。
  • 当用户注销时,只需从数据库中删除该令牌。

(More information)

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11919254

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档