色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

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

  最近對(duì)SQL Server 2008的安全入門略作小結(jié),以作備忘。本文涉及兩個(gè)應(yīng)用存儲(chǔ)過程加密和安全上下文。

  一存儲(chǔ)過程加密

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

  理由如下:

  1、使用存儲(chǔ)過程,至少在防非法注入(inject)方面提供更好的保護(hù)

  至少,存儲(chǔ)過程在執(zhí)行前,首先會(huì)執(zhí)行預(yù)編譯,(如果由于非法參數(shù)的原因)編譯出錯(cuò)則不會(huì)執(zhí)行,這在某種程度上提供一層天然的屏障。

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

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

  2、使用存儲(chǔ)過程而不是直接訪問基表,可以提供更好的安全性

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

  3、存儲(chǔ)過程可以加密

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

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

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

  插入測(cè)試表

use testDb2
go/**********測(cè)試表*****************/
SET ANSI_PADDING
ON
GOCREATE TABLE [dbo].[tb_demo](
 
[id] [int] NOT NULL, [submitdate] [datetime] NULL,
 
[commment] [nvarchar](200) NULL,)GOSET ANSI_PADDING
 
OFFGOInsert 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

it知識(shí)庫SQL Server 2008中的代碼安全(一):存儲(chǔ)過程加密與安全上下文,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 麟游县| 来宾市| 中宁县| 太和县| 灯塔市| 哈巴河县| 平泉县| 仁怀市| 绵竹市| 长白| 盐池县| 永年县| 香港 | 定西市| 扎鲁特旗| 仙居县| 通许县| 岫岩| 江孜县| 德州市| 乌鲁木齐县| 镇宁| 永兴县| 启东市| 临武县| 武平县| 平利县| 公主岭市| 仁怀市| 临汾市| 修水县| 三亚市| 尖扎县| 财经| 密云县| 波密县| 凤庆县| 汝州市| 肃南| 乐业县| 克什克腾旗|