0

0

mysql如何禁用匿名用户_mysql权限加固方案

P粉602998670

P粉602998670

发布时间:2026-01-26 11:05:35

|

252人浏览过

|

来源于php中文网

原创

必须先执行SELECT User,Host FROM mysql.user WHERE User = ''确认匿名用户存在,再DELETE FROM mysql.user WHERE User = ''并立即FLUSH PRIVILEGES;若无结果则无需删除,且需排查root空密码等更常见隐患。

mysql如何禁用匿名用户_mysql权限加固方案

查得到才算真存在:先确认匿名用户是否实际存活

很多人一上来就删,结果发现 SELECT User,Host FROM mysql.user; 里压根没空用户名——那删个寂寞。匿名用户的本质是 User = ''(空字符串),不是 NULL,也不是 'anonymous'。MySQL 5.7+ 默认初始化时可能留一个 ''@'localhost',但 MySQL 8.0+ 安装脚本已默认跳过这步;如果你是离线安装或从旧版本升级而来,才更可能遇到。

  • 执行
    SELECT Host, User FROM mysql.user WHERE User = '';
    —— 只查空字符串,不查 IS NULL,避免误判
  • 如果返回空结果,说明没有匿名用户,后续删除操作可跳过
  • 注意:有些运维脚本会把 ''@'127.0.0.1'''@'localhost' 当成两个,其实它们都算匿名,都要删

删掉它,但别只删一半:DELETE + FLUSH 缺一不可

只执行 DELETE FROM mysql.user WHERE User = ''; 是无效的——MySQL 不会自动重载权限缓存。你立刻再用 mysql -u '' -h localhost 尝试连接,大概率还能进(尤其在未重启服务的情况下)。

  • 必须紧跟着执行
    FLUSH PRIVILEGES;
    ,强制 MySQL 重新读取 mysql.user
  • 不要用 DROP USER ''@'localhost':该语法在 MySQL 5.7 中不支持空用户名,会报错 ERROR 1396 (HY000): Operation DROP USER failed
  • 删除后建议立即验证:再次运行 SELECT User,Host FROM mysql.user WHERE User = '';,确保返回空集

root 密码为空?匿名用户可能只是“替罪羊”

很多所谓“匿名登录成功”,其实是 root 用户密码为空导致的:当你执行 mysql -u root 不输密码就进了,误以为是匿名用户在作祟。这种情况比真正匿名用户更常见,也更危险。

Sheet+
Sheet+

Excel和GoogleSheets表格AI处理工具

下载
  • 检查 root 是否无密码:
    SELECT User,Host,authentication_string FROM mysql.user WHERE User = 'root';
    ,若 authentication_string 为空或为 *(MySQL 5.7),说明密码未设
  • 设密码(MySQL 5.7):
    ALTER USER 'root'@'localhost' IDENTIFIED BY 'YourStrongPass123!';
  • 设密码(MySQL 8.0+):
    ALTER USER 'root'@'localhost' IDENTIFIED WITH caching_sha2_password BY 'YourStrongPass123!';
  • 设完务必再执行 FLUSH PRIVILEGES;,否则新密码不生效

离线安装后最容易漏的三件事

离线部署常跳过初始化安全脚本(如 mysql_secure_installation),导致一堆隐患埋着不动,直到被扫描器打中。

  • test 数据库没删:执行
    DROP DATABASE IF EXISTS test;
    ,并删掉对应权限记录:
    DELETE FROM mysql.db WHERE Db = 'test' OR Db = 'test\\_%';
  • host 限制太宽:检查 root 是否只允许 'localhost',而非 '%';若不需要远程管理,直接删掉所有非 localhost 的 root 记录
  • 没关 skip-grant-tables:检查配置文件 /etc/my.cnf/etc/mysql/my.cnf 里有没有残留的 [mysqld] 下的 skip-grant-tables——有它等于完全放弃权限校验
真正禁用匿名用户,不是执行一条 DELETE 就完事;它是权限加固链条上最基础、却最容易被绕过的环节。只要 FLUSH PRIVILEGES 没跑,或者 root 还裸奔,删了匿名用户也白删。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

666

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

247

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

515

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

256

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

531

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

600

2023.08.14

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

70

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 810人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号