您现在的位置: 无忧电子商务网 >> 信息学院 >> 程序开发 >> php >> 正文

加强用户密码保存及检验的安全性

作者:佚名    信息学院来源:整理    点击数:    更新时间:2008-2-2 我要参与讨论

 

  作者: goseaside
  版权: 遵循 CC 协议 http://creativecommons.org/licenses/by-nc-nd/2.0/deed.zh_TW

  以下 $username, $password 分别指用户名和密码,$sitekey 为站点扰码。


  密码设置

<input type=\"password\" name=\"passwd\" />
<input type=\"hidden\" name=\"t_code0\" />


  提交的时候,使用 javascript 处理

t_code0.value = md5 (username.value + \"|\" + passwd.value);
passwd.value = '';


  如果提交的 passwd 有值或 t_code0 为空,设置密码失败;

  t_code0 的值保存到数据库的 save_pwd 字段中;


  密码校验

  1. 用户端申请登录
  服务器生成随机码 $sid,保存到 $_SESSION[sid] 中,同时传递给用户;

  表单

<input type=\"hidden\" name=\"sid\" value=\"...\" />
<input name=\"username\" />
<input type=\"password\" name=\"passwd\" />
<input type=\"hidden\" name=\"t_code\" />


  2. 用户输入用户名和密码,提交的时候,使用 javascript 处理

var t = md5 (username.value + \"|\" + passwd.value);
t_code.value = md5 (sid + \"|\" + t);
passwd.value = '';

  3. 服务器端判断
  如果 username 为空 或 passwd 非空 或 t_code 为空,返回登录页;
  如没有 $_SESSION[sid],返回登录页;

[php]
$sid0 = $_SESSION[sid];
[/php]


  根据用户名从数据库取 save_pwd,

[php]
$pwd_right = md5("$sid0|$save_pwd");
[/php]


  如果 $pwd_right 和 $t_code 不等,则登录失败;

  清空 sid 值

[php]
$_SESSION[sid] = '';
[/php]


  登录失败,则返回登录页;

优点

[1] [2] 下一页

在google里搜索更多加强用户密码保存及检验的安全性

Google
Web www.51ec.org
【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
我来说两句 对此文章发表了评论
  昵 称: *必填    ·注册用户·
  评 分: 1分 2分 3分 4分 5分     严禁发表危害国家安全、政治、黄色淫秽等内容的评论,用户需对自己在使用本网站服务过程中的行为承担法律责任。本站管理员有权保留或删除评论内容,评论内容只代表机友个人观点,与本网站立场无关。  
评 论
内 容

 
评论列表 (最新 评论仅限网友观点!)

供求信息




| 设为首页 | 加入收藏 | 关于我们 | 广告服务 | 联系方式 | 友情链接 | 版权申明