DVWA项目中的MariaDB认证问题分析与解决方案
问题背景
在使用DVWA(Damn Vulnerable Web Application)项目时,许多用户在配置MariaDB数据库连接时会遇到认证失败的问题。特别是在Kali Linux环境下,当用户尝试通过setup.php页面创建或重置数据库时,系统会抛出"Access denied"错误,提示对'kali'@'localhost'用户的访问被拒绝。
问题分析
这个问题通常由以下几个技术因素导致:
-
认证方式不匹配:MariaDB支持多种认证方式,包括密码认证和Unix socket认证。DVWA默认配置使用的是密码认证方式,但如果用户在MariaDB中配置了socket认证,就会导致连接失败。
-
密码哈希算法兼容性:MariaDB 10.7版本引入了ed25519密码哈希算法,而PHP的MySQL/MariaDB驱动目前还不支持这种新型哈希算法。
-
运行用户权限:当使用socket认证时,MariaDB会检查运行PHP进程的系统用户(通常是www-data)是否在数据库中有对应账号,而不是使用配置文件中指定的用户名。
解决方案
方案一:使用传统密码认证
-
首先确保删除现有的用户账号:
DROP USER 'kali'@'localhost'; -
创建使用传统密码认证的用户:
CREATE USER 'kali'@'localhost' IDENTIFIED BY 'kali'; GRANT ALL PRIVILEGES ON dvwa.* TO 'kali'@'localhost'; FLUSH PRIVILEGES; -
在DVWA的config.inc.php中配置:
$_DVWA[ 'db_server' ] = '127.0.0.1'; $_DVWA[ 'db_database' ] = 'dvwa'; $_DVWA[ 'db_user' ] = 'kali'; $_DVWA[ 'db_password' ] = 'kali';
方案二:使用Unix socket认证
-
创建与PHP运行用户同名的数据库账号:
CREATE USER 'www-data'@'localhost' IDENTIFIED VIA unix_socket; GRANT ALL PRIVILEGES ON dvwa.* TO 'www-data'@'localhost'; FLUSH PRIVILEGES; -
在DVWA的config.inc.php中配置:
$_DVWA[ 'db_server' ] = 'localhost'; // 必须使用localhost才能触发socket连接 $_DVWA[ 'db_database' ] = 'dvwa'; $_DVWA[ 'db_user' ] = 'www-data'; $_DVWA[ 'db_password' ] = ''; // 留空
技术要点
-
localhost与127.0.0.1的区别:在MySQL/MariaDB连接中,使用"localhost"会尝试通过Unix socket连接,而使用IP地址"127.0.0.1"则会通过TCP/IP连接。
-
认证方式选择:Unix socket认证更加安全,因为它不通过网络传输凭证,且依赖于系统用户权限。但密码认证方式更加灵活,适合远程连接场景。
-
密码哈希算法:虽然MariaDB 10.7支持ed25519等新型哈希算法,但PHP的MySQL扩展目前仅支持传统的mysql_native_password和caching_sha2_password算法。
最佳实践建议
-
对于本地开发环境,推荐使用Unix socket认证方式,安全性更高且配置简单。
-
如果必须使用密码认证,建议明确指定使用mysql_native_password算法:
CREATE USER 'kali'@'localhost' IDENTIFIED WITH mysql_native_password BY 'kali'; -
在配置完成后,建议通过命令行测试连接:
mysql -u kali -pkali注意-p参数后直接接密码,不留空格。
通过以上分析和解决方案,用户应该能够顺利解决DVWA与MariaDB之间的认证问题,为后续的Web安全学习和测试奠定基础。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C090
baihu-dataset异构数据集“白虎”正式开源——首批开放10w+条真实机器人动作数据,构建具身智能标准化训练基座。00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python058
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7GLM-4.7上线并开源。新版本面向Coding场景强化了编码能力、长程任务规划与工具协同,并在多项主流公开基准测试中取得开源模型中的领先表现。 目前,GLM-4.7已通过BigModel.cn提供API,并在z.ai全栈开发模式中上线Skills模块,支持多模态任务的统一规划与协作。Jinja00
AgentCPM-Explore没有万亿参数的算力堆砌,没有百万级数据的暴力灌入,清华大学自然语言处理实验室、中国人民大学、面壁智能与 OpenBMB 开源社区联合研发的 AgentCPM-Explore 智能体模型基于仅 4B 参数的模型,在深度探索类任务上取得同尺寸模型 SOTA、越级赶上甚至超越 8B 级 SOTA 模型、比肩部分 30B 级以上和闭源大模型的效果,真正让大模型的长程任务处理能力有望部署于端侧。Jinja00