`
majie
  • 浏览: 75100 次
  • 来自: ...
社区版块
存档分类
最新评论

MySQL的一个小小安全问题(关于匿名用户)

阅读更多
前两天在帮朋友整理他的主页空间时候,发现的一点关于mysql可能大家都会忽略的问题:我们知道,在安装完MySQL后,它会自动创建一个root用户和一个匿名用户,其初始密码都是空,对于前者,很多参考资料上都会提醒大家要注意及时设定一个密码,而忽略了后者,大概是因为后者默认设定为只能在本机使用的缘故吧。

  但如果你的MySQL是要提供给Web服务器作数据库服务的,忽略这个匿名用户的代价可能相当惨重,因为在默认设置下,这个匿名用户在localhost上几乎拥有和root一样的权限,这时候,如果你的客户拥有上传脚本文件、脚本文件可以进行MySQL数据库操作(比如允许操作MySQL的php)的权限已经可能将你的MySQL改动得面目全非了:

  我今天帮朋友整理他的主页空间的时候,试着写了一个很简单的执行sql语句的php文件上传上去,其中连接字中的user,passWord我都试着置空,host=localhost,结果发现我的sql语句可以执行,于是执行select * from MySQL.user察看用户权限,发现这个用户在localhost权限非常高,连grant_priv都有,(察看的时候,会发现在root用户下有两行用户名、密码为空的,但各项权限有y 的,就是这个匿名用户本地、远程权限设置了)

  所以我试着用这个php页面创建一个新用户,并grant给他较高的权限,结果一举成功,这样我就可以用这个新用户通过我本机的MySQL client连接到这个网的MySQL server,并用这个新建立的用户的管理权限对这个网站的MySQL server进行管理,看到自己可以进行这样轻易获得深入的数据库操作,我怎么还敢把朋友的主页空间的敏感资料放入这个MySQL server呢?

  改进建议:

  1、在安装完成MySQL 后,不仅改变root用户的的密码,也同时改变匿名用户的密码,方法类似改变root的密码的方式:

  MySQL> UPDATE user set password=PASSWORD(´yournewpassword´) where user=´´;
  MySQL>FLUSH PRIVILEGES;

  2、如非必要,删除这个匿名用户,这样所有人要使用MySQL 都必须提供用户名,即便日后出了问题,也容易查找问题的源头。

  3、除了root用户外,其他用户包括匿名用户(如果没有删除这个用户)不应该拥有grant权限,防止管理权限不受控制的扩散出去。

  4、赋予用户updatedeletealertcreatedrop权限的时候,应该限定到特定的数据库,尤其要避免普通客户拥有对MySQL数据库做操作的权限,否则你的系统设置很可能被替换掉。

  5、检查MySQL.user表,取消不必要用户的shutdown_priv,reload_priv,process_priv和File_priv权限,这些权限可能泄漏更多的服务器信息包括非MySQL的其它信息出去。

  6、如果不打算让你的用户使用MySQL数据库,在提供诸如php这样的脚本语言的时候,重新设置或编译你的php,取消它们对MySQL的默认支持。
分享到:
评论

相关推荐

    mysql是线程不安全的,mysql不是线程安全的,多线程共用同一个mysql连接是会崩溃的.所以同样QT的QSqlDatabase也是线程不安全的,QS会崩溃

    mysql是线程不安全的,mysql不是线程安全的,多线程共用同一个mysql连接是会崩溃的 QT的QSqlDatabase是基于mysql的,所以一样是线程不安全的 现讲明mysql为什么是线程不安全的,以及在多线程环境下如何使用mysql,...

    MySQL安全配置详解

    MySQL 是一个真正的多用户、多线程 SQL 数据库服务器,它是一个客户机/服务器结构的实现。MySQL 安全配置详解将指导用户如何正确地配置 MySQL,以确保数据库的安全性。 一、MySQL 安装 MySQL 可以在 redhat 环境下...

    MySql数据库安全配置基线

    ### MySQL数据库安全配置基线详解 #### 概述 本文档详细阐述了MySQL数据库的安全配置规范,旨在指导数据库管理员如何确保MySQL数据库系统的安全性。通过遵循本文档中的建议,可以有效地解决数据库的部分安全问题。...

    初始化MySQL用户(删除匿名用户)

    安装完MySQL后,系统默认会创建一个不需要密码的root用户,和一个无用户名无密码的匿名用户(Anonymous Account)。进行下面的初始化操作以合理授权,增强安全。 设置root密码先以root身份登入mysql -u root,设置...

    MYSQL数据库的安全漏洞及防范方法.pdf

    2. 如非必要,删除这个匿名用户,这样所有人要使用MYSQL都必需提供用户名,即便日后出了问题,也容易查找问题的源头。 3. 除了ROOT用户外,其他用户包括匿名用户(如果没有删除这个用户)不直接拥有GRANT权限,防止...

    MySQL安全问题探讨.pdf

    本文将从操作系统层面和数据库自身管理的角度,深入探讨MySQL的安全问题,并提出相应的防范措施。 首先,针对操作系统的安全问题,有以下几个关键点: 1. **严格控制操作系统账号和权限**:数据库服务器上应限制...

    centos 7.1 mysql5.7.12常见问题解决

    解决方法是杀死 MySQL 进程,启动 MySQL 服务,并创建一个软链接到 MySQL 套接字文件。 知识点: * MySQL 服务管理:MySQL 服务的启动和停止是非常重要的,需要正确地管理服务状态。 * MySQL 套接字文件:MySQL ...

    Ubuntu18.0.4安装MySQL并设置ROOT用户密码

    此命令将引导你完成一系列关于安全性的问题,例如设置 ROOT 用户密码、是否删除匿名用户等。 4. **验证 MySQL 服务状态**: ```bash systemctl status mysql.service ``` #### 设置 ROOT 用户密码及允许远程...

    原创的一个PHP+MYSQL论坛

    这个论坛系统是由开发者独立创建的,旨在提供一个在线讨论平台,用户可以在上面发表话题、进行互动交流。PHP是一种广泛使用的开源脚本语言,特别适合于Web开发,而MySQL则是最流行的开源关系型数据库管理系统之一,...

    麒麟V10安装MySQL数据库

    为了提高系统的安全性,创建一个新的用户和用户组专门为MySQL服务,例如,可以创建名为'mysql'的用户和同名的用户组。 接着,创建MySQL所需的相关目录,比如数据存储目录、日志文件目录等。这些目录通常包括 `/var/...

    mysql安装包

    例如,`mysql_system_tables.sql`用于创建系统表,`mysql_secure_installation`脚本用于增强安全性,如删除匿名用户、禁止root远程登录、删除测试数据库等。 5. 设置安全措施:为了保护数据库,强烈建议设置强密码...

    mysql-5.0.X 补丁

    MySQL 5.0版本是一个重要的里程碑,它引入了许多新功能和改进,同时也伴随着一些技术挑战,例如安全性问题。本补丁针对的是MySQL 5.0.x系列的一个特定安全漏洞,即身份认证漏洞。 身份认证漏洞在数据库系统中是个...

    mysql5.7.32最新稳定版本

    MySQL 5.7.32 是 MySQL 数据库管理系统的一个重要稳定版本,对于系统安全性和性能都有显著提升。在本文中,我们将深入探讨 MySQL 5.7.32 的主要特点、在 Linux 上的安装过程以及如何确保数据库的安全性。 1. **...

    mysql基础补充2-用户登录和权限问题

    MySQL 是一个功能强大且广泛使用的关系型数据库管理系统,它提供了丰富的用户登录和权限管理机制,确保数据库的安全性和可靠性。本文将详细介绍 MySQL 的用户登录和权限问题,以 MySQL 5.6 为例,帮助读者深入了解 ...

    mysql-8官方安装zip包

    首先,我们来看“mysql安装和初始化说明.txt”,这是一个重要的文档,它将指导用户如何正确地安装和配置MySQL服务器。安装过程通常包括以下几个步骤: 1. **解压文件**:用户需要将`mysql-8.0.12-winx64.zip`这个...

    windows版mysql安装包-mysql5-mysql-5.5.zip

    - **安全设置**: 使用“mysql_secure_installation”脚本来加强安全性,例如删除匿名用户,禁用远程root登录等。 4. **启动和管理MySQL服务** - **启动/停止服务**: 通过Windows服务管理器或命令行...

    arm架构mysql离线安装包

    对于ARM架构的MySQL,离线安装包可能是一个定制或优化过的版本,以适应特定的硬件需求。 3. **deb-mysqlserver**:在Linux世界中,`.deb`是Debian及其衍生系统(如Ubuntu)使用的软件包格式,用于安装和管理软件。`...

    mysql最佳安全配置手册

    上述安全配置的指导原则,旨在帮助用户从操作系统、文件系统、MySQL基础配置、权限控制、日志审计和身份认证等多方面构建起一个坚固的防御体系,以抵御来自网络的潜在安全威胁。安全配置的实施应结合实际的业务需求...

    基于Servlet JSP MySQL的用户注册模块V1.0

    这个模块允许用户通过一个交互式的网页界面输入他们的个人信息,如用户名、真实姓名和密码,然后将这些数据安全地存储到MySQL数据库中。在这个过程中,涉及到的关键技术包括Servlet、JSP和JDBC。 Servlet是Java编程...

Global site tag (gtag.js) - Google Analytics