婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > SQLServer 2008中的代碼安全(一) 存儲過程加密與安全上下文

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

熱門標簽:浙江地圖標注 創(chuàng)業(yè)電銷機器人 松原導航地圖標注 九鹿林外呼系統(tǒng)怎么收費 沈陽智能外呼系統(tǒng)代理 舞鋼市地圖標注app 電銷機器人虛擬號碼 滄州營銷外呼系統(tǒng)軟件 海南自動外呼系統(tǒng)價格

一>存儲過程加密

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

理由如下:

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

我至今還記得大約八、九年前采用的一個權限控制系統(tǒng)就是通過拼湊一個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條件子句來獲取符合條件的結果集。

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

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

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

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

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

插入測試表

復制代碼 代碼如下:

use testDb2
go

/**********測試表*****************/
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[tb_demo](
[id] [int] NOT NULL,
[submitdate] [datetime] NULL,
[commment] [nvarchar](200) NULL,
)
GO
SET ANSI_PADDING OFF
GO
Insert into [tb_demo]
select 1024, getdate(),REPLICATE('A',100);
WAITFOR DELAY '00:00:04';
Insert into [tb_demo]
select 1024, getdate(),REPLICATE('B',50);
go

插入存儲過程:
復制代碼 代碼如下:

/***************創(chuàng)建未加密的存儲過程*******************/
Create Procedure CPP_test_Original
AS
select * from [tb_demo]
go
/***************創(chuàng)建加密的存儲過程*******************/
Create Procedure CPP_test_Encryption
with encryption
AS
----可以換成任意的邏輯
execute CPP_test_Original
go

未加密的存儲過程:

邀月工作室

加密的存儲過程:

邀月工作室

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

二>安全上下文


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

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

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

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

1、在 SQL Server 中,可以定義以下用戶定義模塊的執(zhí)行上下文:函數(shù)(內(nèi)聯(lián)表值函數(shù)除外)、過程、隊列和觸發(fā)器。

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

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

 

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

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

我們看一個示例:
第一步、創(chuàng)建一個測試存儲過程,用來delete表tb_Demo的所有數(shù)據(jù)
復制代碼 代碼如下:

USE testDb2
GO

CREATE PROCEDURE dbo.[CPP_DEL_ALL_Tb_Demo]
AS
-- Deletes all rows prior to the data feed
DELETE dbo.[tb_Demo]
GO

第二步:創(chuàng)建一個賬號TonyZhang,并賦于該賬號對該存儲過程的exec權限
復制代碼 代碼如下:

USE master
GO
CREATE LOGIN TonyZhang WITH PASSWORD = '123b3b4'
USE testDb2
GO
CREATE USER TonyZhang
GO
GRANT EXEC ON dbo.[CPP_DEL_ALL_Tb_Demo] to TonyZhang

以該賬號登錄SQL Server,并執(zhí)行:
復制代碼 代碼如下:

EXECUTE dbo.CPP_DEL_ALL_Tb_Demo/**(4 row(s) affected)**/

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

Alter PROCEDURE dbo.[CPP_DEL_ALL_Tb_Demo]
AS
-- Deletes all rows prior to the data feed
truncate table dbo.[tb_Demo]
GO

此時,再以TonyZhang登錄,并執(zhí)行存儲過程,會提示:
邀月工作室
這是因為所有者權鏈只限定SELECT、INSERT、UPDATE 和 DELETE。而不包括Truncate,換句話說,系統(tǒng)授于的Exec只既定于SELECT、INSERT、UPDATE 和 DELETE

有人可能會問:如果在存儲過程內(nèi)部調(diào)用動態(tài)語句,而不是明確的表名,我們?nèi)绾蜗薅嘞弈兀?
第三步:我們建立一個存儲過程,功能是傳入一個參數(shù)表名,查詢該表的記錄數(shù)。
復制代碼 代碼如下:

CREATE PROCEDURE dbo.[CPP_SEL_CountRowsFromAnyTable]
@SchemaAndTable nvarchar(255)
AS
EXEC ('SELECT COUNT(1) FROM ' + @SchemaAndTable)
GO

授于Tonyzhang 以執(zhí)行該存儲過程的權限:
復制代碼 代碼如下:

GRANT EXEC ON dbo.[CPP_SEL_CountRowsFromAnyTable] to TonyZhang
go

此時,以Tonyzhang登錄,執(zhí)行存儲過程,會提示:
邀月工作室
注意,此時,tonyzhang雖然有執(zhí)行存儲過程的權限,但是沒有參數(shù)表的select權限,所以執(zhí)行失敗
第四步:修改存儲過程的上下文
創(chuàng)建一個新賬號jackwang,賦于表tb_Demo的select權限
復制代碼 代碼如下:

USE master
GO
CREATE LOGIN JackWang WITH PASSWORD = '123b3b4'
USE Testdb2
GO
CREATE USER JackWang
GRANT SELECT ON OBJECT::dbo.[tb_Demo] TO JackWang
GO

/*******
注意:此時,JackWang 可以執(zhí)行dbo.[tb_Demo的Select
*******/

修改存儲的執(zhí)行者
復制代碼 代碼如下:

USE Testdb2
GO

alter PROCEDURE dbo.[CPP_SEL_CountRowsFromAnyTable]
@SchemaAndTable nvarchar(255)
WITH EXECUTE AS 'JackWang'
AS
EXEC ('SELECT COUNT(1) FROM ' + @SchemaAndTable)
GO

注意:這樣,我們再調(diào)用存儲過程[CPP_SEL_CountRowsFromAnyTable]時,會自動以JackWang的身份運行該存儲過程。
此時,我們?nèi)砸訲onyzhang登錄,再執(zhí)行:
邀月工作室

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

后續(xù)部分將會涉及SQL server 2008新增的透明加密(TDE)功能。
您可能感興趣的文章:
  • SQL Server 2008 存儲過程示例
  • 如何在SQL Server 2008下輕松調(diào)試T-SQL語句和存儲過程
  • sqlserver2008查看表記錄或者修改存儲過程出現(xiàn)目錄名無效錯誤解決方法
  • SQLServer2008存儲過程實現(xiàn)數(shù)據(jù)插入與更新
  • sql server2008調(diào)試存儲過程的完整步驟

標簽:公主嶺 臺灣 日喀則 西藏 寶雞 咸寧 海口 商洛

巨人網(wǎng)絡通訊聲明:本文標題《SQLServer 2008中的代碼安全(一) 存儲過程加密與安全上下文》,本文關鍵詞  SQLServer,2008,中的,代碼,安全,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQLServer 2008中的代碼安全(一) 存儲過程加密與安全上下文》相關的同類信息!
  • 本頁收集關于SQLServer 2008中的代碼安全(一) 存儲過程加密與安全上下文的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    99久久国产综合精品女不卡| 天堂av在线一区| 日韩一级黄色大片| 欧美色区777第一页| 色天使色偷偷av一区二区| 91免费观看视频在线| 99久久精品久久久久久清纯| 99久久99久久免费精品蜜臀| 不卡视频在线观看| 在线观看视频欧美| 欧美一级欧美三级| 精品国内片67194| 欧美激情一区二区三区| 中文成人综合网| 一区二区三区在线视频播放| 亚洲成a人v欧美综合天堂| 日本美女视频一区二区| 免费成人美女在线观看.| 欧美亚洲国产一区二区三区va| 91黄视频在线| 欧美大尺度电影在线| 久久理论电影网| 国产精品美女久久久久aⅴ国产馆| 中文字幕+乱码+中文字幕一区| 亚洲欧美日韩国产综合在线| 午夜精品国产更新| 国产乱人伦精品一区二区在线观看| 国产精品1024久久| 色综合久久中文综合久久97| 欧美日韩1234| 国产欧美日韩激情| 爽爽淫人综合网网站| 国产毛片精品视频| 欧美午夜精品一区二区蜜桃| 欧美va亚洲va香蕉在线| 亚洲人成在线播放网站岛国| 奇米影视一区二区三区| 972aa.com艺术欧美| 91精品国产免费| 国产精品成人免费精品自在线观看| 亚洲成av人片在www色猫咪| 国产一区二区91| 精品视频免费看| 欧美国产日韩亚洲一区| 首页欧美精品中文字幕| 91在线观看地址| 久久综合久久久久88| 亚洲成人av在线电影| 成人爱爱电影网址| 日韩欧美中文一区| 午夜欧美视频在线观看| av在线播放成人| 久久久噜噜噜久久中文字幕色伊伊 | av在线综合网| 欧美成人精精品一区二区频| 婷婷国产在线综合| 欧美性欧美巨大黑白大战| 国产精品欧美久久久久一区二区 | 精品日韩在线观看| 亚洲一区二区三区四区在线观看| 国产成人精品免费在线| 精品少妇一区二区三区在线播放| 日韩综合小视频| 欧美色综合网站| 亚洲精品伦理在线| 99re在线精品| 亚洲人精品午夜| 91浏览器打开| 亚洲欧美激情在线| 91免费观看视频| 一区二区三区国产精品| 色哟哟欧美精品| 一区二区三区四区精品在线视频| 99视频在线精品| 亚洲欧美综合网| 色综合久久六月婷婷中文字幕| 国产精品美日韩| 色欲综合视频天天天| 最新欧美精品一区二区三区| 91麻豆视频网站| 香蕉久久一区二区不卡无毒影院| 欧美猛男gaygay网站| 三级在线观看一区二区 | 这里只有精品99re| 日产国产欧美视频一区精品| 在线不卡a资源高清| 蜜桃视频在线观看一区| 精品免费国产二区三区| 国产999精品久久久久久绿帽| 国产精品蜜臀在线观看| 欧美三级午夜理伦三级中视频| 天天影视涩香欲综合网| 26uuu另类欧美亚洲曰本| 丰满少妇久久久久久久| 亚洲精品视频自拍| 日韩亚洲欧美一区二区三区| 国产成人久久精品77777最新版本| 亚洲欧美综合网| 欧美男生操女生| 国产精品99久久久| 一区二区免费在线播放| 日韩精品中午字幕| 91视频xxxx| 精品中文av资源站在线观看| 中文字幕一区不卡| 日韩欧美你懂的| 91免费国产视频网站| 麻豆国产精品官网| 亚洲男人的天堂av| 日韩欧美专区在线| 色域天天综合网| 国产九九视频一区二区三区| 亚洲一区二区三区四区五区中文| 欧美一级欧美三级在线观看| 色乱码一区二区三区88| 国产乱妇无码大片在线观看| 一区二区三区在线免费| 国产欧美精品一区二区三区四区 | 亚洲精品欧美专区| 日韩精品一区二区三区老鸭窝| 99riav久久精品riav| 日韩精品一二三四| **网站欧美大片在线观看| 精品福利av导航| 宅男噜噜噜66一区二区66| 91麻豆123| av一二三不卡影片| 久久99日本精品| 天堂av在线一区| 亚洲精品成人少妇| 中文字幕在线视频一区| 国产欧美一区二区精品仙草咪| 91精品国产综合久久蜜臀| 欧美视频你懂的| 91免费观看国产| 99精品久久免费看蜜臀剧情介绍| 国产一区二区福利| 国产一区二区看久久| 韩国av一区二区三区在线观看| 一区二区三区日本| 一区二区三区四区在线播放| 国产精品成人一区二区艾草 | 日韩视频免费观看高清在线视频| 欧美这里有精品| 精品1区2区3区| 欧美日韩一区三区| 欧美美女bb生活片| 一区二区三区在线观看动漫| 亚洲欧美日韩久久精品| 亚洲另类在线一区| 亚洲另类在线视频| 亚洲国产视频直播| 亚洲综合视频网| 午夜精品一区二区三区三上悠亚 | 国产精品每日更新在线播放网址| 久久毛片高清国产| 国产精品久久久爽爽爽麻豆色哟哟| 日本一区二区免费在线| 中文成人综合网| 一区二区三区在线视频免费观看| 亚洲狠狠爱一区二区三区| 婷婷丁香激情综合| 国产久卡久卡久卡久卡视频精品| 国产福利视频一区二区三区| 91原创在线视频| 欧美久久一二区| 精品国产乱码久久久久久夜甘婷婷 | 国产精品国产三级国产aⅴ原创 | 在线免费观看一区| 欧美精品电影在线播放| 欧美va亚洲va国产综合| 国产精品美女一区二区在线观看| 一区二区三区美女| 激情深爱一区二区| 风间由美一区二区av101| 在线观看免费成人| 久久久综合九色合综国产精品| 亚洲女同女同女同女同女同69| 视频一区二区国产| 成人免费观看视频| 91精品欧美综合在线观看最新| 久久中文字幕电影| 亚洲综合在线电影| 国产一区二区三区在线观看免费视频| 国产a级毛片一区| 3d动漫精品啪啪一区二区竹菊| 久久亚洲精品小早川怜子| 亚洲黄色小说网站| 国产成人免费高清| 日韩欧美一区二区免费| 日韩毛片精品高清免费| 极品少妇一区二区三区精品视频| 91色视频在线| 国产欧美一区二区精品婷婷| 日韩精品三区四区| proumb性欧美在线观看| 欧美精品一区二区精品网| 亚洲国产日韩一区二区| 成人国产精品免费观看动漫| 精品欧美一区二区久久 |