论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
IT评测·应用市场-qidao123.com技术社区
»
论坛
›
物联网
›
物联网
›
PostgreSQL 创建受限用户并限制数据访问
PostgreSQL 创建受限用户并限制数据访问
滴水恩情
论坛元老
|
6 天前
|
显示全部楼层
|
阅读模式
楼主
主题
1641
|
帖子
1641
|
积分
4923
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
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 安装好搜狗输入法无法输 ...
Linux 进程概念 (上)
nsenter命令简单介绍
GIS数据获取:景象数据免费下载网站 ...
聊聊 C# 和 C++ 中的 泛型模板 底层玩 ...
未来数据库需要关心的硬核创新 ...
一次服务器被入侵的处理过程分享 ...
Kali Linux全网最细安装教程
标签云
AI
运维
CIO
存储
服务器
浏览过的版块
网络安全
CRM
快速回复
返回顶部
返回列表