当前位置: 首页 > news >正文

如何防止SQL注入泄露元数据_限制数据库信息查询权限

禁用元数据访问需分层防控:MySQL用skip-show-databases+限定库权限;PostgreSQL撤回pg_catalog USAGE及关键视图SELECT;SQL Server撤销VIEW DEFINITION;应用层禁用运行时查元数据。MySQL 中如何禁用 information_schema 查询默认情况下,普通用户也能查 information_schema,这是 SQL 注入后获取表名、列名的主要跳板。不能靠“不拼接 SQL”就高枕无忧,得从权限层堵死。实操上,直接回收对 information_schema 的 SELECT 权限无效(MySQL 8.0+ 允许显式授权但不生效),真正有效的是:限制用户只能访问指定数据库,并关闭元数据访问开关。创建用户时用 CREATE USER 'app'@'%' IDENTIFIED BY 'pwd',**不要**加 WITH GRANT OPTION只授具体库权限:GRANT SELECT, INSERT, UPDATE ON myapp_db.* TO 'app'@'%',**不授** mysql 或 information_schema 任何权限MySQL 8.0.29+ 可设系统变量:SET PERSIST information_schema_stats_expiry = 0(降低统计信息缓存,间接增加探测成本,非根治但有干扰作用)关键一步:在 my.cnf 中加 skip-show-databases —— 这会让 SHOW DATABASES 对非 super 用户返回空,连库名都看不到PostgreSQL 怎么关掉 pg_catalog 和 information_schemaPostgreSQL 的元数据更开放,默认所有用户都能查 pg_tables、pg_columns 等视图。不像 MySQL 那样能简单禁用,得靠撤销视图权限 + 撤销 schema 使用权。注意:不能删或重命名 pg_catalog,那是核心 schema;也不能直接 REVOKE SELECT ON ALL TABLES IN SCHEMA pg_catalog,因为部分视图依赖 superuser 权限,普通 revoke 会报错。先确保应用用户不是 pg_read_all_data 角色成员(这个角色默认可读所有系统表)逐个撤回关键视图权限:REVOKE SELECT ON pg_tables, pg_views, pg_columns FROM app_user撤回整个 schema 的使用权限:REVOKE USAGE ON SCHEMA pg_catalog FROM app_user(这步让 SELECT * FROM pg_catalog.pg_tables 直接报 permission denied for schema pg_catalog)PostgreSQL 15+ 支持行级安全策略(RLS),可在 pg_tables 上加策略,但实际中极少用——太重,且 RLS 不作用于元数据视图SQL Server 里 sys.tables 查不到的真正原因SQL Server 默认对普通用户隐藏系统视图内容,但只要用户有 VIEW DEFINITION 权限或属于 db_owner,就能看到真实表结构。泄露常发生在误授了这类权限,或者用了 sa 登录的应用连接字符串。 Vozo Vozo是一款强大的AI视频编辑工具,可以帮助用户轻松重写、配音和编辑视频。

http://www.jsqmd.com/news/668710/

相关文章:

  • 学Simulink——基于Simulink的轴向磁通电机多物理场耦合仿真​
  • 防止SQL注入的核心技术_使用查询参数化处理变量
  • SQL高效合并分散数据的JOIN技巧_利用LEFT JOIN保留全集
  • 2025-2026年朝阳改善楼盘推荐:五大口碑产品评测对比顶尖精英圈层资产保值焦虑 - 品牌推荐
  • 告别编译噩梦:用CMake一次搞定OpenCV 4.5.3 + contrib + VTK 9.0.3的完整开发环境
  • 【IdraScriptsParker】软件启动报错“Run-time error ‘429‘ :ActiveX component can‘ t create object”解决方案
  • 从‘贴图’到‘自适应’:手把手教你用Qt样式表搞定窗口背景(含动态GIF背景教程)
  • OneNet平台生成token注意事项
  • CSS如何通过BEM提升质量_应用命名规范减少Bug产生
  • 2025-2026年朝阳改善楼盘推荐:五大口碑产品评测对比领先核心地段资源稀缺难题 - 品牌推荐
  • WAV音频比特率修改踩坑记:从‘能播’到‘能用’,我如何解决服务器只认64kbps的兼容性问题
  • 保姆级教程:用U深度PE工具箱搞定Windows密码重置与分区调整(附虚拟机实战)
  • HarmonyOS APP开发实战指南:从入门到精通
  • 为什么说2026年,是普通人靠AI逆袭的最后窗口期?
  • 基于Simulink的开关磁阻电机(SRM)非线性转矩脉动抑制
  • RTKLIB开发者笔记:如何为自定义RTCM3消息编写解析模块?
  • 免费AI工具天花板!这10个神器,直接帮你省下上万元
  • 深入浅出聊Boost的‘坏脾气’:从二极管电流看懂右半平面零点(RHPZ)对环路设计的实际影响
  • 2026年企业排班管理方案怎么选?这10个排班管理方案帮你降本增效
  • SketchUp+Enscape渲染卡顿?试试这5个性能优化设置(含草地渲染开关)
  • 紫京宸园优缺点盘点与权威解析:基于区位价值、产品力与市场数据的多维测评. - 品牌推荐
  • 别再只敲lspci了!用这3个命令组合,彻底搞懂Linux下PCIe设备的带宽和性能
  • 紫京宸园价格盘点与权威解析:基于多维数据甄选的价值指南 - 品牌推荐
  • 2025-2026年全球顶层架构设计公司推荐:五大口碑服务评测对比顶尖集团战略转型治理体系优化案例 - 品牌推荐
  • 2025届学术党必备的十大AI写作平台实测分析
  • Python字典底层实现_dict哈希结构解析
  • 别再只盯着水电站了!用储能电站做电网‘黑启动’,这3个实战优势你得知道
  • 自适应滤波入门避坑指南:从维纳滤波到LMS,别再混淆最陡下降和梯度下降了
  • golang如何实现Apple Pay集成_golang Apple Pay集成实现教程
  • 【Selenium】实战:利用CDP协议精准捕获与解析异步网络请求