MSSQL教程之SQL平安设置攻略
支持多线程,充分利用CPU资源平安|攻略日前SQLINJECTION的打击测试愈演愈烈,良多年夜型的网站和论坛都接踵被注进。这些网站一样平常利用的多为SQLSERVER数据库,正由于云云,良多人入手下手嫌疑SQLSERVER的平安性。实在SQLSERVER2000已经由过程了美国当局的C2级平安认证-这是该行业所能具有的最高认证级别,以是利用SQLSERVER仍是相称的平安的。固然和ORCAL、DB2等仍是有差异,可是SQLSERVER的易用性和普遍性仍是能成为我们持续利用下往的来由。那怎样才干使SQLSERVER的设置让人利用的宁神呢?第一步一定是打上SQLSERVER最新的平安补钉,如今补钉已出到了SP3。下载地点:http://www.microsoft.com/sql/downloads/2000/sp3.asp。假如这一步都没有做好,那我们也没有持续下往的需要了。
第二步是修正默许的1433端口,而且将SQLSERVER埋没。如许能克制对试图列举收集上现有的SQLServer客户端所收回的播送作出呼应。别的,还必要在TCP/IP选择中将1433端口屏障失落,尽量的埋没你的SQLSERVER数据库。如许子一但让打击创立了SQLSERVER的账号,也不克不及即刻利用查询剖析器远程上岸来举行下一步的打击。单从ASP,PHP等页面机关歹意语句的话,另有必要检察前往值的成绩,总比不上间接查询剖析器来得拖拉。以是我们起首要做到即便让他人注进了,也不克不及让打击者下一步做得别扭。修正办法:企业办理器-->你的数据库组-->属性-->惯例-->收集设置-->TCP/IP-->属性,在这儿将你的默许端口举行修正,和SQLSERVER的埋没。
第三步是很主要的一步,SQLINJECTION常常在WEBCODE中发生。而做为体系办理员大概数据库办理员,总不克不及经常的往看每段代码。即便经常看代码,也不克不及包管我们在下面的忽略。那怎样办?我们就要从数据库脚色动手,让数据库用户的权限分别到最低点。SQLSERVER的默许权限让人真的很头疼,权限年夜得十分的高,权限小的又甚么都做不了,SYSADMIN和db_owner真是让人又爱又恨。打击者一但确认了网站存在SQLINJECTION毛病,一定有一步操纵步骤就是测试网站的SQLSERVER利用者具有多年夜的权限。一样平常城市借助SELECTIS_SRVROLEMEMBER(sysadmin),大概SELECTIS_MEMBER(db_owner),再大概用user=0(让字符和数字举行对照,SQLSERVER就会提醒了毛病信息,从该信息中便可晓得一些敏感信息)等语句举行测试。办法另有,我也不敢多说了。其一怕错,其二怕同盟中的人扁。在以后,假如网站的数据库利用者用的是SA权限,再加上确认了WEB所处在的相对路径,那末就宣布了你的网站的OVER。db_owner权限也一样,假如确认了相对路径,那末有50%的时机能给你的呆板中上WEB体例的木马,如海阳等。以是这儿我们确认了一点,我们必需要创立自已的权限,让打击者找不着下嘴的中央。在这儿援用一个SQLSERVER联机匡助中的例子:
创立SQLServer数据库脚色的办法(企业办理器)
创立SQLServer数据库脚色
1.睁开服务器组,然后睁开服务器。
2.睁开"数据库"文件夹,然后睁开要在个中创立脚色的数据库。
3.右击"脚色",然后单击"新建数据库脚色"命令。
4.在"称号"框中输出新脚色的称号。
5.单击"增加"将成员增加到"尺度脚色"列表中,然后单击要增加的一个或多个用户。(可选)
只要选定命据库中的用户才干被增加到脚色中。
工具权限
处置数据或实行历程时必要称为工具权限的权限种别:
・SELECT、INSERT、UPDATE和DELETE语句权限,它们能够使用到全部表或视图中。
・SELECT和UPDATE语句权限,它们能够有选择性地使用到表或视图中的单个列上。
・SELECT权限,它们能够使用到用户界说函数。
・INSERT和DELETE语句权限,它们会影响整行,因而只能够使用到表或视图中,而不克不及使用到单个列上。
・EXECUTE语句权限,它们能够影响存储历程和函数。
语句权限
创立数据库或数据库中的项(如表或存储历程)所触及的举动请求另外一类称为语句权限的权限。比方,假如用户必需可以在数据库中创立表,则应当向该用户授与CREATETABLE语句权限。语句权限(如CREATEDATABASE)合用于语句本身,而不合用于数据库中界说的特定工具。
语句权限有:
・BACKUPDATABASE
・BACKUPLOG
・CREATEDATABASE
・CREATEDEFAULT
・CREATEFUNCTION
・CREATEPROCEDURE
・CREATERULE
・CREATETABLE
・CREATEVIEW
表示性权限
表示性权限把持那些只能由预界说体系脚色的成员或数据库工具一切者实行的举动。比方,sysadmin流动服务器脚色成员主动承继在SQLServer安装中举行操纵或检察的全体权限。
数据库工具一切者另有表示性权限,能够对所具有的工具实行统统举动。比方,具有表的用户能够检察、增加或删除数据,变动表界说,或把持同意其他用户对表举行操纵的权限。
db_owner在数据库中有全体权限。
db_accessadmin能够增加或删除用户ID。
db_securityadmin能够办理全体权限、工具一切权、脚色和脚色成员资历。
db_ddladmin能够收回ALLDDL,但不克不及收回GRANT、REVOKE或DENY语句。
db_backupoperator能够收回DBCC、CHECKPOINT和BACKUP语句。
db_datareader能够选择数据库内任何用户表中的一切数据。
db_datawriter能够变动数据库内任何用户表中的一切数据。
db_denydatareader不克不及选择数据库内任何用户表中的任何数据。
db_denydatawriter不克不及变动数据库内任何用户表中的任何数据。
在这儿把新建的数据库脚色的权限设置好,好比必要利用哪一个表、视图、存储历程等。然后把Db_owner和db_securityadmin、db_backupoperator作废,不给打击者BACKUPDATABASE和CREATETABLE的时机,一但打击者具有这两个权限,那末你的网站就还处在非常伤害的形态。另有注重一下,在创立数据库账号时,万万不克不及对服务器脚色举行选择。
第四步是修正SQLSERVER内置存储历程。SQLSERVER估量是为了安装大概别的方面,它内置了一批伤害的存储历程。能读到注册表信息,能写进注册表信息,能读磁盘共享信息等等……列位看到这儿,内心大概会在想,我的网站中有别的的代码,又不像查询剖析器那样能查接将了局输入。给你这个权限,又不克不及怎样,仍是看不到信息。假如列位如许想就年夜错特错了。提醒一下,假如打击者有CREATETABLE的权限,那末创立一个一时表,然后将信息INSERT到表中,然SELECT出来,接着跟数字举行对照,让SQLSERVER报错,那末了局就全出来了……以是我们要报着宁错杀,不放过的立场举行修补。
先来列出伤害的内置存储历程:
xp_cmdshell
xp_regaddmultistring
xp_regdeletekey
xp_regdeletevalue
xp_regenumkeys
xp_regenumvalues
xp_regread
xp_regremovemultistring
xp_regwrite
ActiveX主动剧本:
sp_OACreate
sp_OADestroy
sp_OAMethod
sp_OAGetProperty
sp_OASetProperty
sp_OAGetErrorInfo
sp_OAStop
以上各项全在我们封杀之列,比方xp_cmdshell屏障的办法为:sp_dropextendedprocxp_cmdshell,假如必要的话,再用sp_addextendedprocxp_cmdshell,xpsql70.dll举行恢复。假如你不晓得xp_cmdshell利用的是哪一个.dll文件的话,可使用sp_helpextendedprocxp_cmdshell来检察xp_cmdshell利用的是哪一个静态连接库。别的,将xp_cmdshell屏障后,我们还必要做的步骤是将xpsql70.dll文件举行更名,以避免取得SA的打击者将它举行恢复。
我们做到这儿,你的SQLSERVER就基础上平安了。可是信息仍是能一样的外泄。究竟SELECT我们是没法作废的,除非你的网站用的是HTML。SQLINJECTION的提防还必要我们这些程序员来注重,这才是治标之法。我们在初级设置篇再接着对SQLSERVER的平安做下一步的剖析。该篇文章假如有甚么讹夺,请人人多多包容。感谢……
别的保举一下,SQLINJECTION的测试工具NBSI2,这是由同盟中小竹同道开辟,对SQLINJECTION的注进有代表性的感化,别的一个就是小弟的NBWEBSHELL了。这些工具都能够到同盟网站举行下载
NB同盟-jadesun(裤衩)QQ:280155
NB网站:www.54nb.com
SQL注进进攻办法-程序员篇
NB同盟-小竹
SQL注进愈来愈多的被使用来进侵网站,部分WEB程序员也入手下手存眷这方面的常识,但因为对进侵的办法一孔之见,招致在过滤的时分遗漏某些字符,形成平安毛病;大概是杯弓蛇影,把一些正当的用户哀求都拒之门外,试想一下,当用户想输出个Imaboy的时分,却给你臭骂一顿,他还会乐意再上你的网站吗?
上面,我从程序方面先容一下SQL注进的进攻办法,起首看这三句最复杂SQL语句
1.SQL="Select*fromUserswhereUserID="&Request("ID")
2.SQL="Select*fromUserswhereUserID="&Request("ID")&""
3.SQL="Select*fromUserswhereUserNamelike%"&Request("Name")&"%"
第一句,参数是数字型,这个很分明。第二句,假如字段UserID是int型,就有些人分不分明了。实在,辨别第数字弄和字符型参数,只需看SQL语句参数双方有无单引号便可,很分明,第一句没单引号,是数字型;第二第三句有单引号,是字符型。
关于数字型变量,传进的参数城市间接附加到SQL语句上实行,而由于参数是数字型,以是用isNumeric判别是很平安的,我已经试过用 之类试图断开参数,但了局都是失利。
关于字符型变量,传进的参数都是做为常量,好比你传1and1=1出来,SQL语句就是UserID=1and1=1,在单引号界定局限内里的值永久都只是一个常量,要冲破这个局限,独一的字符就是界定的字符:单引号。以是,字符型变量只需过滤了号就完整平安了,至于怎样过滤,最好是把一个单引号交换成两个单引号,由于SQL语句内里划定,常量如许暗示的常量内里,常量内里假如要有单引号,能够用两个单引号取代。如许,既能够坚持用户输出的原貌,又能够包管程序的平安。
上面是两个函数,人人能够Copy已往间接挪用就好了。
---------------------------------------------------------------
NB同盟防注进函数ReqNum/ReqStr
---------------------------------------------------------------
FunctionReqNum(StrName)
ReqNum=Request(StrName)
ifNotisNumeric(ReqNum)then
Response.Write"参数必需为数字型!"
Response.End
Endif
EndFunction
FunctionReqStr(StrName)
ReqStr=Replace(Request(StrName),"","")
EndFunction
以下面三句SQL语句,申明一下挪用办法:
1.SQL="Select*fromUserswhereUserID="&ReqNum("ID")
2.SQL="Select*fromUserswhereUserID="&ReqStr("ID")&""
3.SQL="Select*fromUserswhereUserNamelike%"&ReqStr("Name")&"%"
重申一点:下面的办法不管对SQLServer库仍是Access或是别的数据库,都是相对合用、相对平安,但注重一点,SQLServer的存储历程是个破例,该情形下要把单引号交换成四个单引号,以保平安。
别的,NB同盟-裤衩已经写过一篇SQLServer平安设置的文章,在程序有毛病的时分,该文章可让进侵者或得尽量少的权限及数据,该文章已宣布在www.54NB.com,有乐趣的能够往看看。
使为了数据安全,我们搭建了主从。但实时主从备份只能防止硬件问题,比如主库的硬盘损坏。但对于误操作,则无能为力。比如在主库误删一张表,或者一个update语句没有指定where条件,导致全表被更新。 对递归类的树遍历很有帮助。个人感觉这个真是太棒了!阅读清晰,非常有时代感。 比如,MicrosoftSQLServer2008的某一个版本可以满足现在的这个业务的需要,而且价格还比Oracle11g要便宜,那么这一产品就是适合的。 这一点很好的加强了profiler的功能。但是提到profiler提醒大家注意一点。windows2003要安装sp1补丁才能启动profiler。否则点击没有反应。 你觉得我的非分区索引无法对起子分区,你可以提醒我一下呀!没有任何的提醒,直接就变成了非分区表。不知道这算不算一个bug。大家也可以试试。 同样会为索引视图等应用带来麻烦。看看行级和事务级的快照数据放在tempdb中,就能感觉到目前架构的尴尬。 where子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用where条件显示特定的行。 可能有的朋友会抱怨集成的orderby,其实如果使用ranking函数,Orderby是少不了的。如果担心Orderby会影响效率,可以为orderby的字段建立聚集索引,查询计划会忽略orderby操作(因为本来就是排序的嘛)。 SQL语言是学习所有数据库产品的基础,无论你是做数据库管理还是做数据库开发都是这样。不过具体学习的侧重点要看你将来做哪一块,如果是做数据库管理(DBA),侧重点应该放在SQLServer的系统管理上.
页:
[1]