PostgreSQL 的 CREATE STATISTICS 未检查 schema 的 CREATE 权限 HGVE-2025-E010

文章目录

环境

系统平台:N/A

版本:9.0.3,9.0.4,6.0.4,4.5.9,4.5.10,4.5.11

BUG/漏洞编码

HGVE-2025-E010,CVE-2025-12817

症状

在 PostgreSQL 的 CREATE STATISTICS 命令中,由于缺少权限检查,表的所有者可以在任意 schema 中创建统计对象,从而对其他具有 CREATE STATISTICS 权限的用户造成拒绝服务攻击(DoS)。

如果某用户之后尝试使用 CREATE STATISTICS 创建同名统计对象(并且拥有该 schema 的 CREATE 权限),将会因为名称已被占用而失败。受影响的版本为:PostgreSQL 18.1、17.7、16.11、15.15、14.20 和 13.23 之前的所有版本。

触发条件

CREATE STATISTICS 命令在执行时存在权限检查缺陷。虽然该命令要求用户必须是相关表的所有者,但未正确验证用户是否在目标 schema 上具有 CREATE 权限。这违反了 PostgreSQL 的安全模型,允许表所有者在没有相应 schema 创建权限的情况下,在该 schema 中创建统计对象,从而导致潜在的命名空间冲突和拒绝服务攻击。

解决方案

PostgreSQL 官方修复方案是在 CREATE STATISTICS 命令执行前增加对 schema CREATE 权限的检查:

/* 修复代码示例 */

AclResult aclresult;

// 在 CreateStatistics 函数中添加权限检查

aclresult = pg_namespace_aclcheck(statrelnamespace, GetUserId(), ACL_CREATE);if (aclresult != ACLCHECK_OK)

aclcheck_error(aclresult, OBJECT_SCHEMA, get_namespace_name(statrelnamespace));

补丁下载地址:

链接: https://pan.baidu.com/s/14h-y1lf64w8xJUR9jYBlFQ?pwd=cwh6 提取码: cwh6

相关推荐
mpHH7 小时前
postgresql-分区表
数据库·postgresql
AC赳赳老秦7 小时前
OpenClaw与WPS宏联动:批量执行WPS复杂操作,解决办公表格批量处理难题
java·前端·数据库·自动化·需求分析·deepseek·openclaw
杜子不疼.7 小时前
用 JiuwenSwarm 搭建 SRE 智能值班体系:告警分级、根因分析与应急手册生成
数据库
接着奏乐接着舞7 小时前
java 数据结构
数据库·redis·缓存
时空自由民.7 小时前
PID介绍
数据库·mongodb
m0_609160497 小时前
如何用 some 检测数组中是否存在至少一个满足条件的项
jvm·数据库·python
|_⊙7 小时前
Linux 深入理解文件(Ext2文件系统:上)
linux·运维·数据库
情绪总是阴雨天~7 小时前
大模型 Function Call(函数调用)详解:原理、实践与数据库智能查询 Agent
前端·数据库·人工智能
m0_702036538 小时前
如何从Oracle Java调用外部API_HTTP请求在数据库Java Source中的实现
jvm·数据库·python