Oracle使用者訪問許可權與PUBLIC角色的關係
在資料庫中建立了一個使用者,這是給第三方系統用的。客戶強調,這個使用者只能訪問到有限的表,在我們規定的範圍內的表。
於是,我建立 一個使用者,如user_third ,只給了connect 角色,用grant select on table 有限授權。
為此,我寫了一文,請見 如何實現 中使用者 B只能訪問使用者 A的檢視 ( )
使用者訪問密碼交給客戶後,又發現一個新問題,它居然能訪問其他使用者的表。
我核實了一下,發現它確實能訪問別的使用者的表。如資料 庫中TT 使用者下的表。
這是怎麼回事?
您從我列出的標題中,一定猜到了吧。這事一定 public 角色有關。
在 Oracle TimeTen 建立時,它建立的表會自動將它的查詢許可權授予給 public 角色。
而資料庫中任何一個使用者都預設擁有 public 角色。
因此,問題就在 public 角色的許可權上。我們只需要查詢 public 角色授予了哪些許可權,再撤銷這些許可權即可。
透過執行下列 SQL ,我們能判斷出哪些許可權授予給了 public 角色。
SELECT GRANTOR,OWNER,TABLE_NAME,PRIVILEGE FROM DBA_TAB_PRIVS WHERE GRANTEE='PUBLIC';
部分結果如下:
GRANTOR OWNER TABLE_NAME PRIVILEGE
------------------------------ ----------------------------------------
×× GTJA TT_03_24577_L UPDATE
GTJA GTJA TT_03_24577_L SELECT
GTJA GTJA TT_03_24577_L INSERT
GTJA GTJA TT_03_24577_L DELETE
TT 表的查詢更新刪除插入許可權都授予給了public 角色。這個很恐怖,對資料庫系統的安全是有破壞的。
基於此,我們可以判定任何一個資料庫使用者都可以對這些表做查詢更新刪除插入操作。
怎麼解決這個許可權問題,是很簡單的。但一定要保證不能影響到TT 的正常使用。這是個權衡的問題,可用性和安全兩個角度的權衡。如果TT 不正常了,就考慮將其遷移到其他庫上去,最好是獨立的僅供TT 使用的庫。
具體解決方法如下:
1 、從Oracle TimeTen 上解決,在建立cachegroup 時,將授予公共許可權的選項除掉。當然這麼做的前提是要保證TT 能夠正常使用。
2 、從資料庫中將這些許可權從public 角色撤銷。同樣前提是TT 在這些許可權撤銷後能正常工作。
撤銷方法示例如下:
revoke select on TT_03_24577_L from public;
總結一下,這個例項說明了Oracle 的許可權真夠複雜的,日常管理時一定要留意一下public 角色的許可權。
更多Oracle相關資訊見 專題頁面
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/90618/viewspace-1124959/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- public, private, protected 訪問許可權訪問許可權
- Oracle使用者角色許可權管理Oracle
- 005.OpenShift訪問控制-許可權-角色
- Quarkus中基於角色的許可權訪問控制教程
- postgresql關於訪問檢視需要的許可權SQL
- 使用者角色許可權管理架構架構
- ubuntu 開放root使用者的SSH訪問許可權Ubuntu訪問許可權
- java中public,protected,private關鍵字以及預設訪問許可權修飾符的用法細節Java訪問許可權
- win10老跳出訪問許可權怎麼辦_win10訪問許可權怎麼關閉Win10訪問許可權
- Rbac使用者角色許可權表設計
- mongoDB 3.0 安全許可權訪問MongoDB
- Java 訪問許可權控制(6)Java訪問許可權
- k8s結合jumpserver做kubectl許可權控制 使用者在多個namespaces的訪問許可權 rbac許可權控制K8SServernamespace訪問許可權
- 關於SQL Server資料庫中的使用者許可權和角色管理SQLServer資料庫
- C++中類繼承public,protected和private關鍵字作用詳解及派生類的訪問許可權C++繼承訪問許可權
- 由於GDPR Instapaper暫時關閉了歐洲使用者的訪問許可權訪問許可權
- 關於IPC和PTH使用者許可權問題,psexec拒絕訪問(Access Denied)的原因
- 17-成員訪問許可權訪問許可權
- 使用nginx控制ElasticSearch訪問許可權NginxElasticsearch訪問許可權
- Linux使用者與許可權Linux
- GitHub的Repository許可權將public轉為privateGithub
- Laravel——使用者角色許可權控制包 Laravel-permissionLaravel
- 無程式碼實現CRM角色許可權問題
- 遇到問題,需要開發角色許可權模組
- Spring安全的角色和許可權原始碼與教程 - javadevjournalSpring原始碼Javadev
- win共享檔案沒有許可權訪問怎麼辦 win10共享檔案許可權訪問的方法Win10
- Sql Server關於許可權、角色以及登入名、使用者名稱的總結SQLServer
- DBA 日常:規模使用者資料庫訪問許可權管理資料庫訪問許可權
- MongoDB 使用者與許可權管理MongoDB
- 論Java訪問許可權控制的重要性Java訪問許可權
- Ubuntu共享資料夾訪問許可權問題Ubuntu訪問許可權
- 物件與引用,static關鍵字,程式碼塊,包,訪問許可權修飾符物件訪問許可權
- 用無程式碼解決CRM角色許可權問題
- 如何在 Linux 中配置 sudo 訪問許可權Linux訪問許可權
- mongodb關於使用者許可權的總結MongoDB
- MySQL5.7&8.0許可權-角色管理MySql
- 使用者角色許可權控制包 Laravel-permission 使用說明Laravel
- Ant Design Pro v4 基於角色的許可權訪問控制實戰教程 #1 介紹
- 淺析Windows的訪問許可權檢查機制Windows訪問許可權