存儲過程加密其實,用了這十多年的SQLserver,我已經成了存儲過程的忠實擁躉。在直接使用SQL語句還是存儲過程來處理業務邏輯時,我基本會毫不猶豫地選擇后者。理由如下:1、使用存儲過程,至少在防非法注入(inject)方面提供更好的保護。至少,存儲過程在執行前,首先會執行預編譯,(如果由于非" />

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

SQL Server 2008中的代碼安全(一):存儲過程

系統 2201 0

SQL Server 2008中SQL應用系列--目錄索引

最近對SQL Server 2008的安全入門略作小結,以作備忘。本文涉及兩個應用:存儲過程加密和安全上下文。

<一>存儲過程加密

其實,用了這十多年的SQL server,我已經成了存儲過程的忠實擁躉。在直接使用SQL語句還是存儲過程來處理業務邏輯時,我基本會毫不猶豫地選擇后者。

理由如下:

1、使用存儲過程,至少在防非法注入(inject)方面提供更好的保護 。至少,存儲過程在執行前,首先會執行預編譯,(如果由于非法參數的原因)編譯出錯則不會執行,這在某種程度上提供一層天然的屏障。

我至今還記得大約八、九年前采用的一個權限控制系統就是通過拼湊一個SQL語句,最終得到了一個形如“ where 1=1 and dataID in (1,2) and ModelID in (2,455) And ShopID in (111) and departID in ( 1,3) and ([Name] like %myword%) ”的where條件子句來獲取符合條件的結果集。

注意:這個參數是通過地址欄web應用的地址欄或Winform的UI界面來輸入的,所以對惡意注入需要花費一定的成本來維護。因為一些常用的關鍵字(或敏感詞)很難區分是惡意或非惡意。

2、使用存儲過程而不是直接訪問基表,可以提供更好的安全性 。你可以在行級或列級控制數據如何被修改。相對于表的訪問,你可以確認有執行權限許可的用戶執行相應的存儲過程。這也是訪問數據服務器的惟一調用途徑。因此,任何偷窺者將無法看到你的SELECT語句。換句話說,每個應用只能擁有相應的存儲過程來訪問基表,而不是“SLEECT *”。

3、存儲過程可以加密 。(這點非常實用,設想一下,您的數據庫服務器是托管的或租用的,你是否能心安理得的每天睡個安穩覺。如果競爭對手“一不小心”登上你的SQL Server,或通過注入得到了你的存儲過程,然后相應的注入惡意的SQL,將您的業務邏輯亂改一通,而恰巧您五分鐘前又沒做備份,那會怎么樣?)

(注意: 加密存儲過程前應該備份原始存儲過程,且加密應該在部署到生產環境前完成。)

存儲過程的加密非常簡單,我們看一個例子:

插入測試表

插入存儲過程:

未加密的存儲過程:

加密的存儲過程:

此時,至少,存儲過程的內容不會被輕易看到(雖然解密也是有可能的)。應用這個,我們可以對某些關鍵的存儲過程進行加密。 但此時,存儲過程仍然能被execute、alter和drop。

<二>安全上下文


除了加密sql文本的內容,我們還可以使用 EXECUTE AS 子句設定存儲過程的安全上下文,以滿足不同的安全級別需求。

如果你對這些不感興趣,請直接路過帶下劃線的段落。

(關于 EXECUTE AS 子句的詳細用法,請參看MSDN: http://msdn.microsoft.com/zh-cn/library/ms188354.aspx)

此處,我們需要了解的是:

1、在 SQL Server 中,可以定義以下用戶定義模塊的執行上下文: 函數(內聯表值函數除外)、過程、隊列和觸發器。

通過指定執行模塊的上下文,可以控制數據庫引擎使用哪一個用戶帳戶來驗證對模塊引用的對象的權限。這有助于人們更靈活、有力地管理用戶定義的模塊及其所引用對象所形成的對象鏈中的權限。必須而且只需授予用戶對模塊自身的權限,而無需授予用戶對被引用對象的顯式權限。只有運行模塊的用戶必須對模塊訪問的對象擁有權限。

針對函數、過程、隊列和觸發器,對應的參數也不同。存儲過程對應的參數包括( CALLER | SELF | OWNER | 'user_name ')。

CALLER 指定模塊內的語句在模塊調用方的上下文中執行。執行模塊的用戶不僅必須對模塊本身擁有適當的權限,還要對模塊引用的任何數據庫對象擁有適當權限。 CALLER 是除隊列外的所有模塊的默認值,與 SQL Server 2005 行為相同。 CALLER 不能在 CREATE QUEUE 或 ALTER QUEUE 語句中指定。
SELF EXECUTE AS SELF 與 EXECUTE AS user_name 等價,其中指定用戶是創建或更改模塊的用戶。創建或更改模塊的用戶的實際用戶 ID 存儲在 sys.sql_modules sys.service_queues 目錄視圖的 execute_as_principal_id 列中。SELF 是隊列的默認值。
OWNER 指定模塊內的語句在模塊的當前所有者上下文中執行。如果模塊沒有指定的所有者,則使用模塊架構的所有者。不能為 DDL 或登錄觸發器指定 OWNER。注意: OWNER 必須映射到單獨帳戶,不能是角色或組。
'user_name' 指定模塊內的語句在 user_name 指定的用戶的上下文中執行。將根據 user_name 來驗證對模塊內任意對象的權限。不能為具有服務器作用域的 DDL 觸發器或登錄觸發器指定 user_name。請改用 login_name。user_name 必須存在于當前數據庫中,并且必須是單獨帳戶。user_name 不能是組、角色、證書、密鑰或內置帳戶,如 NT AUTHORITY/LocalService、NT AUTHORITY/NetworkService 或 NT AUTHORITY/LocalSystem。執行上下文的用戶 ID 存儲在元數據中,可以在 sys.sql_modules 或 sys.assembly_modules 目錄視圖的 execute_as_principal_id 列查看。

2、所有權鏈具有以下限制:
僅適用于 DML 語句:SELECT、INSERT、UPDATE 和 DELETE。
調用和被調用對象的所有者必須相同。
不適用于模塊內的動態查詢。

我們看一個示例:
第一步、創建一個測試存儲過程,用來delete表tb_Demo的所有數據

第二步:創建一個賬號TonyZhang,并賦于該賬號對該存儲過程的exec權限

以該賬號登錄SQL Server,并執行:

注意:此時, 雖然TonyZhang除了執行存儲過程[CPP_DEL_ALL_Tb_Demo]之外沒有任何其他權限,但仍然執行了存儲過程,并刪除了表記錄。
如果我們修改存儲過程為:

此時,再以TonyZhang登錄,并執行存儲過程,會提示:

這是因為所有者權鏈只限定在SELECT、INSERT、UPDATE 和 DELETE。而不包括Truncate,換句話說,系統授于的Exec只既定于SELECT、INSERT、UPDATE 和 DELETE

有人可能會問:如果在存儲過程內部調用動態語句,而不是明確的表名,我們如何限定權限呢?
第三步:我們建立一個存儲過程,功能是傳入一個參數表名,查詢該表的記錄數。

授于Tonyzhang 以執行該存儲過程的權限:

此時,以Tonyzhang登錄,執行存儲過程,會提示:

注意,此時,tonyzhang雖然有執行存儲過程的權限,但是沒有參數表的slect權限,所以執行失敗。
第四步:修改存儲過程的上下文
創建一個新賬號jackwang,賦于表tb_Demo的select權限

修改存儲的執行者

注意:這樣,我們再調用存儲過程[CPP_SEL_CountRowsFromAnyTable]時,會自動以JackWang的身份運行該存儲過程。
此時,我們仍以Tonyzhang登錄,再執行:


小結:
本文通過簡單的兩個示例開始SQL server代碼的安全之旅,
1、存儲過程的加密,(注意: 加密存儲過程前應該備份原始存儲過程,且加密應該在部署到生產環境前完成。)
2、存儲過程的安全上下文。可以通過上下文設置更加嚴格的數據訪問級別。(主要是對 SELECT、INSERT、UPDATE 和 DELETE 語句的訪問限制)

后續部分將會涉及SQL server 2008新增的透明加密(TDE)功能。

邀月注:本文版權由邀月和CSDN共同所有,轉載請注明出處。
助人等于自助! 3w@live.cn

SQL Server 2008中的代碼安全(一):存儲過程加密與安全上下文


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 婷婷尹人香蕉久久天堂 | 欧美77| 黄色一级毛片 | 逼逼网 | 亚洲综合无码一区二区 | 精品在线一区二区三区 | 九九热热九九 | 久久久久在线 | 精品自拍视频 | 欧美激情人成日本在线视频 | 边摸边吃奶边做激情叫床文章 | 欧美很黄视频在线观看 | 国产精品视_精品国产免费 亚洲综合在线另类色区奇米 | 奇米影视8888 | 日本高清va不卡视频在线观看 | 国产成年网站v片在线观看 中文字幕在线免费视频 | 亚洲欧洲精品在线 | 天干夜天天夜天干天 | 成人欧美在线观看 | 国产高清www免费视频 | 黄色影片在线免费观看 | 青娱乐在线免费观看视频 | 欧美午夜精品久久久久免费视 | 午夜免费观看福利片一区二区三区 | 99精品在线 | 精品伊人网 | 日韩高清免费在线观看 | 国产换爱交换乱理伦片 | 欧美日韩三区 | 全黄裸片武则天一级第4季 亚洲一区国产 | 色呦呦免费观看 | 亚洲日韩中文字幕天堂不卡 | 在线精品亚洲欧美日韩国产 | 久草日韩 | 极品美女一区二区三区视频 | 国产国语一级a毛片高清视频 | 五月色播影音在线观看 | 成人免费观看在线网址 | 亚洲精品第一国产综合高清 | 久久精品亚洲 | 亚洲欧美在线精品一区二区 |