用户名
Email
论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
应用中心
帖子
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
账号登录
立即注册
找回密码
用户名
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
qidao123.com技术社区-IT企服评测·应用市场
»
论坛
›
物联网
›
物联网
›
PostgreSQL 创建受限用户并限制数据访问
PostgreSQL 创建受限用户并限制数据访问
滴水恩情
论坛元老
|
2025-4-19 01:52:55
|
显示全部楼层
|
阅读模式
楼主
主题
1706
|
帖子
1706
|
积分
5118
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
PostgreSQL 创建受限用户并限制数据访问
要实现创建一个只能访问特定表且只能看到特定组织数据(org_id=123)的用户,同时禁止访问hs_disce表,可以按照以下步骤操作:
1. 创建新用户
CREATE USER restricted_user WITH PASSWORD 'secure_password';
复制代码
2. 授予基本毗连权限
GRANT CONNECT ON DATABASE your_database TO restricted_user;
复制代码
3. 授予特定表的访问权限
GRANT USAGE ON SCHEMA public TO restricted_user;
GRANT SELECT ON hs_report_task TO restricted_user;
GRANT SELECT ON hs_recipel TO restricted_user;
GRANT SELECT ON hs_recipel_item TO restricted_user;
复制代码
4. 设置行级安全策略(RLS)
起首确保表已启用行级安全:
ALTER TABLE hs_report_task ENABLE ROW LEVEL SECURITY;
ALTER TABLE hs_recipel ENABLE ROW LEVEL SECURITY;
ALTER TABLE hs_recipel_item ENABLE ROW LEVEL SECURITY;
复制代码
然后为每张表创建策略:
-- 对hs_report_task表的策略
CREATE POLICY org_restriction_policy_report_task ON hs_report_task
FOR SELECT
TO restricted_user
USING (org_id = 123);
-- 对hs_recipel表的策略
CREATE POLICY org_restriction_policy_recipel ON hs_recipel
FOR SELECT
TO restricted_user
USING (org_id = 123);
-- 对hs_recipel_item表的策略
CREATE POLICY org_restriction_policy_recipel_item ON hs_recipel_item
FOR SELECT
TO restricted_user
USING (org_id = 123);
复制代码
5. 确保用户无法访问hs_disce表
REVOKE ALL PRIVILEGES ON hs_disce FROM restricted_user;
复制代码
6. 可选:创建视图简化访问
假如必要,可以为该用户创建视图:
CREATE VIEW restricted_user_hs_report_task AS
SELECT * FROM hs_report_task WHERE org_id = 123;
GRANT SELECT ON restricted_user_hs_report_task TO restricted_user;
-- 对其他表重复类似操作
复制代码
验证设置
使用新用户登录:
psql -U restricted_user -d your_database
复制代码
尝试查询数据:
SELECT * FROM hs_report_task; -- 应该只看到org_id=123的数据
SELECT * FROM hs_disce; -- 应该被拒绝
复制代码
这样设置后,restricted_user用户将只能看到三张指定表中org_id=123的数据,而无法访问hs_disce表或其他不符合条件的数据。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
继续阅读请点击广告
回复
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
滴水恩情
论坛元老
这个人很懒什么都没写!
楼主热帖
体系集成商重返黄金年代
SFSafariViewController 加载的网页与 ...
ubuntu 20.04 安装好搜狗输入法无法输 ...
聊聊 C# 和 C++ 中的 泛型模板 底层玩 ...
nsenter命令简单介绍
Linux 进程概念 (上)
GIS数据获取:景象数据免费下载网站 ...
未来数据库需要关心的硬核创新 ...
Spark快速上手(2)Spark核心编程-RDD简 ...
一次服务器被入侵的处理过程分享 ...
标签云
国产数据库
集成商
AI
运维
CIO
存储
服务器
快速回复
返回顶部
返回列表