常见问题解决 --- discuz密码忘记
在使用discuz官方论坛里的tools工具发现没有用
于是分析网站日志,发现登录失败日志D:\wwwroot\网站root\data\log\202307_illegallog.php,里面保存时间 、用户名、密码、ip
通过log文件名搜索代码,定位到写入log的函数地方,从而找到密码认证的地方。通过分析
打印变量到日志作为调试
$errorlog = dhtmlspecialchars('$action'.$action);
writelog('illegallog', $errorlog);
文件内容搜索的方式配合最终定位到如下代码
if(empty($user)) { $status = -1; } elseif(!$_ENV['user']->verify_password($password, $user['password'], $user['salt'])) {//:`$_ENV`是PHP的一个全局变量,用于存储环境变量。这里的`$_ENV['user']`表示在环境变量中用户对象的引用。->对象操作符,类似java的。verify_password这是一个方法调用,调用了名为`verify_password`的方法,并传入三个参数:用户提供的密码`$password`、存储在用户对象中的密码`$user['password']`通常是经过加密处理的字符串。和盐值`$user['salt']`一个随机的字符串(盐值),用于增加密码的安全性。该方法的作用是将用户输入的密码与存储在用户对象中的密码进行比较,以验证密码的正确性。在方法内部,通常会使用一定的算法将输入的密码与盐值进行处理,然后与存储的密码进行比较,以判断密码是否匹配。密码 ddd120508,哈希 be7982a98b4edd3cc8d67369d1ec275e,盐 空 $status = -2; //测试发现返回-2提示登陆失败 //
我们注意到是使用的是PHP内置方法
verify_password
进行密码匹配
因此修改数据库 pre_ucenter_member 的password 改为 7f08d654bc1baef5c810ede044fb677c ,salt改为 6950e2
此时密码就是12345678
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用