MySQL匿名空用户名处理
问题描述:公司漏扫发现数据库内出现空用户名及密码,需要对这些用户进行整改

1.首先出现了疑问,这些空的用户名是怎么出现的,而且不附带密码。
2.可以手动这样创建这样的用户名和密码形式么。
3.如果能这样创建一个用户,是不是我可以不用用户名和密码能直接登录服务器呢。
4.如何对这样的形式存在进行规避。
空用户名为匿名用户,那么匿名用户能登录么,登录方式可以不用带用户名么。延伸到了mysql的匿名用户,安装完MySQL后,系统默认会创建一个不需要密码的root用户,和一个无用户名无密码的匿名用户(Anonymous Account)。进行下面的初始化操作以合理授权,增强安全。
mysql> create user ''@'localhost' ;
Query OK, 0 rows affected (0.00 sec)
mysql> select user,host,authentication_string from mysql.user;
+------------------+-----------+------------------------------------------------------------------------+
| user | host | authentication_string |
+------------------+-----------+------------------------------------------------------------------------+
| employee_proxy | % | *DC6775B6D1F01EFD99CC191E929862480DAC2F7A |
| root | % | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| test01 | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| tspmlf | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| username | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| | localhost | |
| backuper | localhost | *4DDFC2472B45DA20DB77FD7F3C19996CCCE35897 |
| employee | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| mysql.infoschema | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.session | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.sys | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| root | localhost | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| zabbix | localhost | *C5A9E29672800EE5E1A1B0EA8C397728FD1660D8 |
+------------------+-----------+------------------------------------------------------------------------+
13 rows in set (0.00 sec)
[mysql@rhel7 ~]$ /usr/local/mysql8/bin/mysql -u -p -hlocalhost -P33306 -S /data/mysql8/db_dxpt08/mysql.sock
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 11
Server version: 8.0.22 MySQL Community Server - GPL Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
--测试证明,采用匿名登录测试可以直接登录数据库,不过登录进来权限受限制
mysql>
mysql> show grants for ''@'localhost' ;
+--------------------------------------+
| Grants for @localhost |
+--------------------------------------+
| GRANT USAGE ON *.* TO ``@`localhost` |
+--------------------------------------+
1 row in set (0.00 sec)
mysql> select current_user(),user();
+----------------+--------------+
| current_user() | user() |
+----------------+--------------+
| @localhost | -p@localhost |
+----------------+--------------+
1 row in set (0.00 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
+--------------------+
1 row in set (0.00 sec)
mysql>
mysql>
mysql> select user,host from mysql.user;
ERROR 1142 (42000): SELECT command denied to user ''@'localhost' for table 'user'
如何进行规避,删除这种方式
--用drop ‘’@‘localhost’ 方式进行删除
mysql> select user,host,authentication_string from mysql.user;
+------------------+-----------+------------------------------------------------------------------------+
| user | host | authentication_string |
+------------------+-----------+------------------------------------------------------------------------+
| employee_proxy | % | *DC6775B6D1F01EFD99CC191E929862480DAC2F7A |
| root | % | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| test01 | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| tspmlf | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| username | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| | localhost | |
| backuper | localhost | *4DDFC2472B45DA20DB77FD7F3C19996CCCE35897 |
| employee | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| mysql.infoschema | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.session | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.sys | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| root | localhost | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| zabbix | localhost | *C5A9E29672800EE5E1A1B0EA8C397728FD1660D8 |
+------------------+-----------+------------------------------------------------------------------------+
13 rows in set (0.00 sec) mysql> drop user ''@'localhost';
Query OK, 0 rows affected (0.01 sec) mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec) mysql> select user,host,authentication_string from mysql.user;
+------------------+-----------+------------------------------------------------------------------------+
| user | host | authentication_string |
+------------------+-----------+------------------------------------------------------------------------+
| employee_proxy | % | *DC6775B6D1F01EFD99CC191E929862480DAC2F7A |
| root | % | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| test01 | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| tspmlf | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| username | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| backuper | localhost | *4DDFC2472B45DA20DB77FD7F3C19996CCCE35897 |
| employee | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| mysql.infoschema | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.session | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.sys | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| root | localhost | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| zabbix | localhost | *C5A9E29672800EE5E1A1B0EA8C397728FD1660D8 |
+------------------+-----------+------------------------------------------------------------------------+
12 rows in set (0.00 sec)
--delete from mysql.user where user='';
mysql> create user ''@'127.0.0.1' ;
Query OK, 0 rows affected (0.01 sec) mysql> select user,host,authentication_string from mysql.user;
+------------------+-----------+------------------------------------------------------------------------+
| user | host | authentication_string |
+------------------+-----------+------------------------------------------------------------------------+
| employee_proxy | % | *DC6775B6D1F01EFD99CC191E929862480DAC2F7A |
| root | % | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| test01 | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| tspmlf | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| username | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| | 127.0.0.1 | |
| backuper | localhost | *4DDFC2472B45DA20DB77FD7F3C19996CCCE35897 |
| employee | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| mysql.infoschema | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.session | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.sys | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| root | localhost | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| zabbix | localhost | *C5A9E29672800EE5E1A1B0EA8C397728FD1660D8 |
+------------------+-----------+------------------------------------------------------------------------+
13 rows in set (0.00 sec) mysql> delete from mysql.user where user='';
Query OK, 1 row affected (0.00 sec) mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec) mysql> select user,host,authentication_string from mysql.user;
+------------------+-----------+------------------------------------------------------------------------+
| user | host | authentication_string |
+------------------+-----------+------------------------------------------------------------------------+
| employee_proxy | % | *DC6775B6D1F01EFD99CC191E929862480DAC2F7A |
| root | % | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| test01 | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| tspmlf | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| username | % | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
| backuper | localhost | *4DDFC2472B45DA20DB77FD7F3C19996CCCE35897 |
| employee | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| mysql.infoschema | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.session | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| mysql.sys | localhost | $A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED |
| root | localhost | *858D7135C67CFFAEE40C01A38AB99018DBB245A7 |
| zabbix | localhost | *C5A9E29672800EE5E1A1B0EA8C397728FD1660D8 |
+------------------+-----------+------------------------------------------------------------------------+
12 rows in set (0.00 sec)
匿名用户一般会在刚创建完数据库时,用来防止用户忘记登录密码。如果不及时清理掉,会暴露一个风险给漏扫。
MySQL匿名空用户名处理的更多相关文章
- 何修改WAMP中mysql默认空密码--转
何修改WAMP中mysql默认空密码 http://www.cnblogs.com/hooray/archive/2011/07/23/2114792.html WAMP安装好后,mysql密码是为 ...
- paip.导入数据英文音标到数据库mysql为空的问题之道解决原理
paip.导入数据英文音标到数据库mysql为空的问题之道解决原理 #---原因:mysql 导入工具的bug #---解决:使用双引号不个音标括起来. 作者 老哇的爪子 Attilax 艾龙, E ...
- WAMP中修改mysql默认空密码
WAMP中如何修改mysql默认空密码 WAMP安装好后,mysql教程密码是为空的,那么要如何修改呢?其实很简单,通过几条指令就行了,下面我就一步步来操作.首先,通过WAMP打开mysql控制台.提 ...
- 解决windows下的mysql匿名登陆无法使用mysql数据库的问题
原文:解决windows下的mysql匿名登陆无法使用mysql数据库的问题 我在windows下安装了mysql,但是不用密码就能登进去,而root明明是有密码的,我用select user()命令 ...
- MySQL设置空密码
因为刚安装的时候,MySQL强制设置密码,但是我需要设置MySQL为空密码 语句: ';
- 【转】修改mysql数据库的用户名和密码
修改mysql数据库的用户名和密码 更改密码 mysql -u root -p Enter password:*** mysql>use mysql; 选择数据库 Database change ...
- c# 调用mysql数据库验证用户名和密码
使用mysql数据库验证用户名和密码时,如果用户名是中文,一直查不到数据 需要把app.config 中修改为 数据库统一设置utf8编码格式,连接数据库的时候设置编码Charset=utf8可以避免 ...
- 修改WAMP中mysql默认空密码
WAMP安装好后,mysql密码是为空的,那么要如何修改呢?其实很简单,通过几条指令就行了,下面我就一步步来操作. 首先,通过WAMP打开mysql控制台. 提示输入密码,因为现在是空,所以直接按回车 ...
- 如何修改WAMP中mysql默认空密码
WAMP安装好后,mysql密码是为空的,那么要如何修改呢?其实很简单,通过几条指令就行了,下面我就一步步来操作. 首先,通过WAMP打开mysql控制台. 提示输入密码,因为现在是空,所以直接按 ...
- 如何修改WAMP中mysql默认空密码 以及修改时报错的处理方法
WAMP安装好后,mysql密码是为空的,那么要如何修改呢?其实很简单,通过几条指令就行了,下面我就一步步来操作. 首先,通过WAMP打开mysql控制台. 提示输入密码,因为现在是空,所以直接按回车 ...
随机推荐
- Spring RedisTemplate源码解读
RedisTemplate类位于项目spring-data-redis-xxx的包org.springframework.data.redis.core下,是我们在Spring框架下操作Redis数据 ...
- 阿里云Linux服务器部署JDK8实战教程
下载地址 https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 文件上传 把下载的文 ...
- Qt编译问题之FTH (7156) Fault tolerant heap shim applied to current process
有时候Qt编译会出现FTH: (7156): *** Fault tolerant heap shim applied to current process. This is usually due ...
- MySQL查询和事务
数据库关联查询 内连接查询(inner join) SELECT * FROM tb1 INNER JOIN tb2 ON 条件 左表查询(左关联查询)(left join) 查询两个表共有的数据,和 ...
- MySQL的卸载与安装
卸载 1.右键点击我的电脑 -->服务-->停掉MySQL的服务 2.控制面板卸载MySQL 3.删除隐藏文件夹 C:\ProgramData下的MySQL文件夹 4.删除MySQL文件夹 ...
- vue + vant 移动端适配
1. 设置动态根字号大小,/public/phone-adapt.js,在index.html中引入 (function (doc, win) { const docEl = win.document ...
- 【Unity】protobuf故意踩坑记
写在前面 起因:我看到工作项目使用protobuf来做序列化时脑子冒出许多问号,"以前我按<Unity3D网络游戏实战>做坦克游戏时为了让客户端和服务器使用统一协议用到了prot ...
- Docker 环境规划 (Docker安装)
一.环境规划 支持Java.dotNet.Vue项目构建 二.切换系统镜像源 1.备份 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.rep ...
- 如何优化MySQL
1.MySQL数据库作发布系统的存储,一天五万条以上的增量,预计运维三年,怎么优化? a. 设计良好的数据库结构,允许部分数据冗余,尽量避免join查询,提高效率.b. 选择合适的表字段数据类型和存储 ...
- USB 驱动框架分析
这里先说一些概念性的东西,了解一下USB 一.关于usb设备 都见过很多,用过很多了,每当我们插上一个usb设备到pc的时 右下角就会弹出一个提示信息,提示"发现xxx"设备,再接 ...