返回介绍

5.4 MySQL 数据库安全

发布于 2024-10-03 00:33:42 字数 2824 浏览 0 评论 0 收藏 0

使用 MySQL,安全问题不能不注意。以下是 MySQL 提示的 23 个注意事项:

  1. 如果客户端和服务器端的连接需要跨越并通过不可信任的网络,那么就需要使用 SSH 隧道来加密该连接的通信。
  2. set password 语句来修改用户的密码(防止明文传输密码),三个步骤,先 mysql -u root 登陆数据库系统,然后 mysql> update mysql.user set password=password('newpwd') ,最后执行 flush privileges 就可以了。
  3. 需要提防的攻击有,防偷听、篡改、回放、拒绝服务等,不涉及可用性和容错方面。对所有的连接、查询、其他操作使用基于 ACL 即访问控制列表的安全措施来完成。也有一些对 SSL 连接的支持。
  4. 除了 root 用户外的其他任何用户不允许访问 mysql 主数据库中的 user 表;

加密后存放在 user 表中的加密后的用户密码一旦泄露,其他人可以随意用该用户名/密码相应的数据库;

  1. 用 grant 和 revoke 语句来进行用户访问控制的工作;
  2. 不使用明文密码,而是使用 md5()sha1() 等单向的哈系函数来设置密码;
  3. 不选用字典中的字来做密码;
  4. 采用防火墙来去掉 50%的外部危险,让数据库系统躲在防火墙后面工作,或放置在 DMZ 区域中;
  5. 从因特网上用 nmap 来扫描 3306 端口,也可用 telnet server_host 3306 的方法测试,不能允许从非信任网络中访问数据库服务器的 3306 号 TCP 端口,因此需要在防火墙或路由器上做设定;
  6. SQL 注入:为了防止被恶意传入非法参数,例如 where ID=234 ,别人却输入 where ID=234 OR 1=1 导致全部显示,所以在 web 的表单中使用 ''"" 来用字符串,在动态 URL 中加入 %22 代表双引号、 %23 代表井号、 %27 代表单引号;传递未检查过的值给 mysql 数据库是非常危险的;
  7. 在传递数据给 mysql 时检查一下大小;
  8. 应用程序需要连接到数据库应该使用一般的用户帐号,只开放少数必要的权限给该用户;
  9. 在各编程接口 (C C++ PHP Perl Java JDBC 等) 中使用特定 逃脱字符 函数(转义字符?mysql_real_escape_string);在因特网上使用 mysql 数据库时一定少用传输明文的数据,而用 SSL 和 SSH 的加密方式数据来传输;
  10. 学会使用 tcpdump 和 strings 工具来查看传输数据的安全性,例如 tcpdump -l -i eth0 -w -src or dst port 3306 | strings 。以普通用户来启动 mysql 数据库服务;
  11. 不使用到表的联结符号,选用的参数 --skip-symbolic-links;
  12. 确信在 mysql 目录中只有启动数据库服务的用户才可以对文件有读和写的权限;
  13. 不许将 process 或 super 权限付给非管理用户,该 mysqladmin processlist 可以列举出当前执行的查询文本;super 权限可用于切断客户端连接、改变服务器运行参数状态、控制拷贝复制数据库的服务器;

18.file 权限不付给管理员以外的用户,防止出现 load data '/etc/passwd' 到表中再用 select 显示出来的问题;

  1. 如果不相信 DNS 服务公司的服务,可以在主机名称允许表中只设置 IP 数字地址;
  2. 使用 max_user_connections 变量来使 mysqld 服务进程,对一个指定帐户限定连接数;

21.grant 语句也支持资源控制选项;

  1. 启动 mysqld 服务进程的安全选项开关, --local-infile=0 或 1 若是 0 则客户端程序就无法使用 local load data 了,赋权的一个例子 grant insert(user) on mysql.user to 'user_name'@'host_name'; 若使用 --skip-grant-tables 系统将对任何用户的访问不做任何访问控制,但可以用 mysqladmin flush-privilegesmysqladmin reload 来开启访问控制;默认情况是 show databases 语句对所有用户开放,可以用 --skip-show-databases 来关闭掉。
  2. 碰到 Error 1045(28000) Access Denied for user 'root'@'localhost' (Using password:NO) 错误时,你需要重新设置密码,具体方法是:先用 --skip-grant-tables 参数启动 mysqld,然后执行 mysql -u root mysql,mysql>update user set password=password('newpassword') where user='root';mysql>Flush privileges; ,最后重新启动 mysql 就可以了。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文