国外设计欣赏网站 - DOOOOR.com

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,微信登陆

搜索

[Drupal问题] Drupal 7:如何重置admin用户密码(新型的Hash加密)

[复制链接]
发表于 1-29-2012 15:40 | 显示全部楼层 |阅读模式

由于好久没有登录本机的Drupal 7网站,发现早已忘记了admin密码。打开phpmyadmin想直接数据库更改密码,却发现Drupal 7已不再采用Drupal 6和5时代的简单的MD5加密了。据某个帖子说是因为现在有一个在线的MD5数据库,可以查到很多MD5码的原文,因此Drupal 7的开发者认为不能再继续采用这种极不安全的方法了,因此Drupal 7采用了新型的Hash加密方法来确保密码安全。


新型加密码方法是“加了盐(Salt)“的MD5码,简单理解就是并不会直接将password进行MD5加密,而会和用户名或其它随机字符串组合在一起后再MD5加密。具体的技术细节不是本文想讨论的。:-)

下面说如何更改密码(因为找回是没有可能的了)。


在Drupal 7的安装目录中的scripts目录下,有一些Drupal 7开发者准备好的PHP脚本,可以执行一些高级操作。其中有一个脚本名为:password-hash.sh,它的功能是传入一个密码(字符串),即返回加密后的密码字符串。在使用前要将php的php.exe路径加入系统的PATH环境变量中,这样在任何目录中均可以直接使用php.exe(我使用的是Windows 7操作系统)。


假设密码是“ilovedrupal”,那么需使用下面的命令获得新密码:

php scripts/password-hash.sh ‘ilovedrupal’ > new_pwd.txt

这样新的密码即存放在new_pwd.txt文件中,打开后,hash后面的字符串即为加密后的密码。如下。

password: 'ilovedrupal'         hash: $S$Cv8Wnz0EiNg3Bi19w27wo.uITAX.dnYxbiMeYcSHIvC8TFLVdKB9

hash后的字符串可以通过phpmyadmin直接更新进users表中。若使用的是SQLite数据库,则需要使用SQLLite命令行客户端。

但是,我遇到了新的问题。由于刚开始试验几次密码没有成功,更改了新密码后,Drupal仍提示:
Sorry, there have been more than 5 failed login attempts for this account. It is temporarily blocked. Try again later or request a new password.

这是由于Drupal 7默认如果试5次登录均未成功,则6小时之内不能登录。这些信息记录在flood表中。所以解决的办法就是手动清空flood表。


清空后使用新密码,登录成功。


摘自:方医生 798



-----------------------------------------------------------------------------------------------------------------------------------------------------------


评 论

我使用了此语句 php scripts/password-hash.sh ‘ilovedrupal’ > new_pwd.txt
为什么每次生成的 hash 都不一样?而且直接更新进users 也没有用

使用的是Drupal7.4

是的,每次生成的密码是不一样的。因为在生成时,好像加入了时间戳(未证实)等随机数。
提示什么错误?

我用你所提供的数据
password: 'ilovedrupal' hash: $S$Cv8Wnz0EiNg3Bi19w27wo.uITAX.dnYxbiMeYcSHIvC8TFLVdKB9

还是无法登录!

我把自己的密码改成 ilovedrupal 后,去查数据库,里面是

$S$C9wjEzqFN2heKUX4YN0btCci6JNEGfQWKk05TzNvWYapNOiF0rRA

请问下,是不是Drupal7.4在密码保存方面又做了某些修改?

应该没有修改的。是不是提示“超过5次不能登录“?

|2011-2026-版权声明|平台(网站)公约|DOOOOR 设计网 ( 吉ICP备2022003869号 )

GMT+8, 2-15-2025 05:44 , Processed in 0.424022 second(s), 194 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表