阿裡雲RDS for SQL Serrver關於許可權的一個嚴重Bug

来源:https://www.cnblogs.com/kerrycode/archive/2019/10/23/11729816.html
-Advertisement-
Play Games

阿裡雲RDS for SQL Server的賬號管理有不少小Bug,而且有一個很嚴重的Bug:任何普通賬號,都能創建資料庫。註意,我這裡是說任意普通賬號,任意任意普通賬號!任意任意普通賬號!重要的事情說三遍。 例如,下麵測試環境所示,RDS for SQL Server的資料庫版本為SQL Serv... ...


阿裡雲RDS for SQL Server的賬號管理有不少小Bug,而且有一個很嚴重的Bug:任何普通賬號,都能創建資料庫。註意,我這裡是說任意普通賬號,任意任意普通賬號!任意任意普通賬號!重要的事情說三遍。

 

 

例如,下麵測試環境所示,RDS for SQL Server的資料庫版本為SQL Server 2016 WEB,我們在控制平臺的賬號管理界面,創建一個資料庫賬號test2,如下所示,只授予只讀許可權。

 

clip_image001

 

 

我們使用腳本get_login_rights_script.sql 獲取資料庫賬號test2的具體許可權如下所示:

 

clip_image002

 

使用test2賬號登錄資料庫,執行下麵腳本就能創建一資料庫,如下所示。根據個人的測試,這個賬號可以為任意普通賬號。即使取消伺服器角色setupamin與processadmin,依然是可以創建資料庫的。

 

 

CREATE DATABASE [MyDB]
 CONTAINMENT = NONE
 ON  PRIMARY 
( NAME = N'MyDB', FILENAME = N'E:\SQLDATA\DATA\MyDB.mdf' , SIZE = 5120KB , FILEGROWTH = 10%)
 LOG ON 
( NAME = N'MyDB_log', FILENAME = N'E:\SQLDATA\DATA\MyDB_log.ldf' , SIZE = 1024KB , FILEGROWTH = 10%)
GO

 

如果可以創建資料庫,當然也可以刪除資料庫,當然,只能刪除它自己創建的資料庫,不能刪除其它資料庫。

 

DROP DATABASE MyDB;

 

刪除不是這個賬號創建的資料庫時就會報錯。如下所示:

 

DROP DATABASE test4;
 
Msg 3701, Level 11, State 2, Line 15
Cannot drop the database 'test4', because it does not exist or you do not have permission.

 

 

是否很神奇?傳統資料庫需要有伺服器角色dbcreator(當然,sysadmin角色肯定也可以) 或者授予CREATE ANY DATABASE、 CREATE DATABASE, ALTER ANY DATABASE其中一個許可權才能創建資料庫。但是RDS for SQL Server的普通賬號沒有授予這些許可權,卻依然可以創建資料庫。實在是想不明白它為什麼有這樣一個Bug。 RDS for SQL Server的高許可權賬號有許可權限制,所以很多事情也無法更深入的去探究。目前,我們也提交、報告了這個問題,暫時還沒有得到官方回覆!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 有時候我們在測試配置外網IP是不是成功時,我們需要使用一些命令,使用 ssh 登錄可以查看ip, 還有一種可以使用命令: 進行方便獲取,公網IP;真的是非常好的服務; 保持更新,更多內容,請關註 cnblogs.com/xuyaowen; ...
  • 玩過 Linux 的同學,幾乎都用過虛擬機!然而,你們肯定不曉得?不用裝虛擬機,也有體驗 Linux 的辦法。下麵一起來看看吧,到底如何不用虛擬機,照樣能玩 Linux。 其實方法很簡單,你只需要擁有一臺可以聯網的電腦,直接訪問以下網址。 1. "JS/UIX Terminal" 直接進入,點擊 o ...
  • 本次是一個 Firewalld 的基礎操作實例,利用 Firewalld 圖形操作界面進行訪問控制操作。 ...
  • 下載安裝rtpMIDI (網路MIDI驅動程式) 打開rtpMIDI,在“My session”那裡按下+,就會自動顯示你的電腦的名字 檢查Bonjour服務正常運行,iPad與pc網路正常連接 iPad端運行midi鍵盤程式,進入midi設置,設置為網路連接(可用於iPad的midi模擬應用Pia ...
  • 背景 最近在Linux官網下載了Linux內核,下載下來的是一個尾碼為.tar.xz的壓縮包,於是在毫不知情的情況下隨隨便便解壓了,解壓過程中出現了很多問題。 其中一個問題就是在Windows下,不區分大小寫的文件名,但是在Ubuntu下就可以區分。比如,abc.txt和ABC.txt會被認為是同一 ...
  • 點擊【虛擬機】選項中的【安裝VMware Tools】,此時在Ubuntu的桌面上就會出現一個光碟圖標。 如果之前已經安裝過了,【虛擬機】選項中應為【重新安裝VMware Tools】。 如果【重新安裝VMware Tools】選項是灰色的,則需要點擊【虛擬機】選項中的【設置】,在【設置】中點擊【C ...
  • 正文: Setup 1 系統信息 安裝 貼下系統信息 [圖1] 下麵是已經安裝完成的Telnet版本查詢,如果還沒有安裝的是沒有包信息顯示的。[圖2] Telnet 遠程登陸工具,Windows裡面常常用來測試埠用(- .- !),Xinetd 第一次看見,百科里說是監視網路需求的守護進程(不曉得 ...
  • 資料庫基礎 第一章:資料庫的簡介 資料庫 資料庫(dataBase,DB)是指長期存儲在電腦內的,有組織,可共用的數據的集合。 資料庫中的數據按一定的數學模型組織、描述和存儲,具有較小的冗餘,較高的數據獨立性和易擴展性,並可為各種用戶共用。資料庫管理系統軟體 資料庫管理系統(Database Ma ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...