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

主頁(yè) > 知識(shí)庫(kù) > SQLServer 2008中的代碼安全(一) 存儲(chǔ)過(guò)程加密與安全上下文

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

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

一>存儲(chǔ)過(guò)程加密

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

理由如下:

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

我至今還記得大約八、九年前采用的一個(gè)權(quán)限控制系統(tǒng)就是通過(guò)拼湊一個(gè)SQL語(yǔ)句,最終得到了一個(gè)形如“ 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條件子句來(lái)獲取符合條件的結(jié)果集。

注意:這個(gè)參數(shù)是通過(guò)地址欄web應(yīng)用的地址欄或Winform的UI界面來(lái)輸入的,所以對(duì)惡意注入需要花費(fèi)一定的成本來(lái)維護(hù)。因?yàn)橐恍┏S玫年P(guān)鍵字(或敏感詞)很難區(qū)分是惡意或非惡意。

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

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

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

存儲(chǔ)過(guò)程的加密非常簡(jiǎn)單,我們看一個(gè)例子:

插入測(cè)試表

復(fù)制代碼 代碼如下:

use testDb2
go

/**********測(cè)試表*****************/
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

插入存儲(chǔ)過(guò)程:
復(fù)制代碼 代碼如下:

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

未加密的存儲(chǔ)過(guò)程:

邀月工作室

加密的存儲(chǔ)過(guò)程:

邀月工作室

此時(shí),至少,存儲(chǔ)過(guò)程的內(nèi)容不會(huì)被輕易看到(雖然解密也是有可能的)。應(yīng)用這個(gè),我們可以對(duì)某些關(guān)鍵的存儲(chǔ)過(guò)程進(jìn)行加密。但此時(shí),存儲(chǔ)過(guò)程仍然能被execute、alter和drop

二>安全上下文


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

如果你對(duì)這些不感興趣,請(qǐng)直接路過(guò)帶下劃線的段落。

(關(guān)于EXECUTE AS 子句的詳細(xì)用法,請(qǐng)參看MSDN:http://msdn.microsoft.com/zh-cn/library/ms188354.aspx)

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

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

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

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

 

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

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

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

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)建一個(gè)賬號(hào)TonyZhang,并賦于該賬號(hào)對(duì)該存儲(chǔ)過(guò)程的exec權(quán)限
復(fù)制代碼 代碼如下:

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

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

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

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

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

此時(shí),再以TonyZhang登錄,并執(zhí)行存儲(chǔ)過(guò)程,會(huì)提示:
邀月工作室
這是因?yàn)樗姓邫?quán)鏈只限定SELECT、INSERT、UPDATE 和 DELETE。而不包括Truncate,換句話說(shuō),系統(tǒng)授于的Exec只既定于SELECT、INSERT、UPDATE 和 DELETE

有人可能會(huì)問(wèn):如果在存儲(chǔ)過(guò)程內(nèi)部調(diào)用動(dòng)態(tài)語(yǔ)句,而不是明確的表名,我們?nèi)绾蜗薅?quán)限呢?
第三步:我們建立一個(gè)存儲(chǔ)過(guò)程,功能是傳入一個(gè)參數(shù)表名,查詢?cè)摫淼挠涗洈?shù)。
復(fù)制代碼 代碼如下:

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

授于Tonyzhang 以執(zhí)行該存儲(chǔ)過(guò)程的權(quán)限:
復(fù)制代碼 代碼如下:

GRANT EXEC ON dbo.[CPP_SEL_CountRowsFromAnyTable] to TonyZhang
go

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

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

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

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

USE Testdb2
GO

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

注意:這樣,我們?cè)僬{(diào)用存儲(chǔ)過(guò)程[CPP_SEL_CountRowsFromAnyTable]時(shí),會(huì)自動(dòng)以JackWang的身份運(yùn)行該存儲(chǔ)過(guò)程。
此時(shí),我們?nèi)砸訲onyzhang登錄,再執(zhí)行:
邀月工作室

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

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

標(biāo)簽:公主嶺 臺(tái)灣 日喀則 西藏 寶雞 咸寧 海口 商洛

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQLServer 2008中的代碼安全(一) 存儲(chǔ)過(guò)程加密與安全上下文》,本文關(guān)鍵詞  SQLServer,2008,中的,代碼,安全,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQLServer 2008中的代碼安全(一) 存儲(chǔ)過(guò)程加密與安全上下文》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于SQLServer 2008中的代碼安全(一) 存儲(chǔ)過(guò)程加密與安全上下文的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲天堂a在线| 精品欧美一区二区三区精品久久| 男人的天堂亚洲一区| 国产iv一区二区三区| 欧美精品欧美精品系列| 亚洲日本青草视频在线怡红院| 天堂av在线一区| 色欧美88888久久久久久影院| 中文字幕欧美一区| 国内欧美视频一区二区| 91一区二区在线| 日韩精品一区二区三区四区| 久久精品二区亚洲w码| 91蜜桃在线免费视频| 久久精品一区四区| 91视频国产观看| 国产欧美日韩三级| 狠狠狠色丁香婷婷综合久久五月| 国产三级三级三级精品8ⅰ区| 久久激情综合网| 91精品国产综合久久精品图片| 日韩亚洲欧美在线观看| 久久国产免费看| 91精品国产91综合久久蜜臀| 国产片一区二区三区| 色偷偷久久一区二区三区| 国产日韩精品一区二区浪潮av | 欧美mv日韩mv| 免费在线观看视频一区| 日韩一区二区三区电影在线观看| 国产精品66部| 国产精品美女一区二区在线观看| 国产一区二区在线免费观看| 一区二区三区免费网站| 在线亚洲高清视频| 亚洲国产欧美在线人成| 成人高清免费在线播放| 丝袜美腿亚洲一区二区图片| 91精品蜜臀在线一区尤物| 免费观看在线色综合| 亚洲精品视频免费观看| 色综合久久综合网97色综合| 亚洲美女免费在线| 欧美精品一区二区三区在线 | 亚洲午夜久久久久久久久电影院 | 欧美一区永久视频免费观看| 午夜欧美视频在线观看| 欧美精品 国产精品| 国产精品一二三在| 久久久精品黄色| 色综合天天综合色综合av| 国产精品婷婷午夜在线观看| 99国产精品99久久久久久| 亚洲女与黑人做爰| 91婷婷韩国欧美一区二区| 男男gaygay亚洲| 国产精品无码永久免费888| 91丨九色丨蝌蚪富婆spa| 国产主播一区二区| 亚洲蜜桃精久久久久久久| 欧美中文字幕不卡| gogogo免费视频观看亚洲一| 日日夜夜一区二区| 欧美经典一区二区| 日本一区二区三级电影在线观看| 在线观看网站黄不卡| 国产激情91久久精品导航 | 国产麻豆日韩欧美久久| 怡红院av一区二区三区| 亚洲欧美日韩久久精品| 日韩精品一区二区三区在线| 成人av在线资源网| 亚洲自拍另类综合| 亚洲国产日韩在线一区模特| 国产精品视频看| 精品国产污污免费网站入口 | 精品三级av在线| 欧美图片一区二区三区| 国产一区二区三区四区五区美女| 精品动漫一区二区三区在线观看| 精品一区免费av| 夜夜操天天操亚洲| 国产精品久久久久久福利一牛影视 | 精品国产乱码久久久久久老虎| 成人性生交大片| 亚洲香肠在线观看| 亚洲黄色尤物视频| 夜夜嗨av一区二区三区| 日本成人中文字幕在线视频| 一区二区欧美国产| 亚洲伦理在线精品| 2021中文字幕一区亚洲| 国产精品对白交换视频| 中文字幕精品一区二区三区精品| 精品国产免费人成在线观看| 国产精品电影院| 亚洲特黄一级片| 亚洲黄色片在线观看| 亚洲永久精品大片| 老司机一区二区| 韩国女主播成人在线| 狠狠色狠狠色综合| 国产黄人亚洲片| 成人免费视频app| aa级大片欧美| 欧美tickle裸体挠脚心vk| 精品久久久久99| 久久伊99综合婷婷久久伊| 亚洲欧美国产三级| 亚洲一区二区三区免费视频| 婷婷久久综合九色国产成人| 亚洲第一福利一区| 丁香六月综合激情| av一二三不卡影片| 欧美视频一区二区| 亚洲免费观看视频| 久久综合久色欧美综合狠狠| 91精品国产综合久久久久久久久久 | 菠萝蜜视频在线观看一区| av动漫一区二区| 成人a免费在线看| 国产三级精品视频| 一区二区三区精品在线| 亚洲欧洲日产国码二区| 精品一区在线看| 色香蕉久久蜜桃| 亚洲欧美一区二区久久| 精品一区二区三区影院在线午夜| 亚洲不卡一区二区三区| 91免费看`日韩一区二区| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲国产精品尤物yw在线观看| 亚洲成人高清在线| 亚洲毛片av在线| 成人丝袜高跟foot| 91麻豆福利精品推荐| 久久久久久免费网| 亚洲欧洲精品天堂一级| 日本不卡不码高清免费观看| 欧美自拍偷拍一区| 欧美日本韩国一区| 国产人成一区二区三区影院| 国产大陆a不卡| 色综合中文综合网| 久久精品国产精品青草| 亚洲国产精品久久艾草纯爱| 国产精品国产三级国产专播品爱网| 国产乱理伦片在线观看夜一区| 色综合婷婷久久| 久久精品一区二区三区不卡 | 成人福利电影精品一区二区在线观看| 91.com在线观看| 亚洲欧美福利一区二区| 国产a精品视频| 久久久www免费人成精品| 亚洲欧美成人一区二区三区| 久久99热狠狠色一区二区| 国内精品伊人久久久久av影院| 日韩欧美www| 蜜臀久久久久久久| 欧美日韩不卡一区二区| 日韩va欧美va亚洲va久久| 欧美人与性动xxxx| 亚洲一区二区高清| 色综合久久综合| 亚洲一区二区三区四区不卡| 91色在线porny| 亚洲人成网站精品片在线观看 | 欧美精品乱码久久久久久按摩 | 欧美日韩免费在线视频| 日韩激情视频网站| 欧美三级中文字| 午夜精品影院在线观看| 激情综合网最新| 精品播放一区二区| 国产精品一区免费在线观看| 欧美成va人片在线观看| 国产一区二区三区| 国产午夜精品一区二区三区视频| 成人动漫在线一区| 亚洲自拍偷拍综合| 国产色产综合色产在线视频| 国产高清精品在线| 国产精品成人一区二区三区夜夜夜| 欧美日韩精品久久久| 日韩精品一二三| 亚洲欧美日韩中文播放 | 国产日韩欧美在线一区| 337p亚洲精品色噜噜狠狠| 欧美精品久久一区二区三区| 制服丝袜激情欧洲亚洲| 欧美电影在线免费观看| 在线电影国产精品| 欧美一级欧美一级在线播放| 欧美va亚洲va| 中文字幕精品一区二区三区精品 | 亚洲精品菠萝久久久久久久| 亚洲最新视频在线观看| 奇米精品一区二区三区四区 | 青青草国产精品亚洲专区无|