sqlserver数据库安全配置规范

发布时间:   来源:文档文库   
字号:


竭诚为您提供优质文档/双击可除

sqlserver数据库安全配置规范


篇一:sqlserver2000的安全配置sqlserver2000的安全配置
sqlserver2000的安全配置在进行sqlserver2000数据库的安全配置之前,首先你必须对操作系统进行安全配置,保证你的操作系统处于安全状态。然后对你要使用的操作数据库软件(程序)进行必要的安全审核,比如对aspphp等脚本,这是很多基于数据库的web应用常出现的安全隐患,对于脚本主要是一个过滤问题,需要过滤一些类似,;@/字符,防止破坏者构造恶意的sql语句。接着,安装sqlserver2000后请打上补丁sp1以及最新的sp2下载地址是:/sql/downloads/2000/sp1.asp/sql/downloads/2000/sp2.asp
在做完上面三步基础之后,我们再来讨论sqlserver安全配置。
1、使用安全的密码策略
我们把密码策略摆在所有安全配置的第一步,请注意,很多数据库帐号的密码过于简单,这跟系统密码过于简单是


111



一个道理。对于sa更应该注意,同时不要让sa帐号的密码写于应用程序或者脚本中。健壮的密码是安全的第一步!sqlserver2000安装的时候,如果是使用混合模式,那么就需要输入sa的密码,除非你确认必须使用空密码。这比以前的版本有所改进。同时养成定期修改密码的好习惯。数据库管理员应该定期查看是否有不符合密码要求的帐号。比如使用下面的sql语句:usemaster
selectname,passwordfromsysloginswherepasswordisnull2、使用安全的帐号策略
由于sqlserver不能更改sa用户名称,也不能删除这个超级用户,所以,我们必须对这个帐号进行最强的保护,当然,包括使用一个非常强壮的密码,最好不要在数据库应用中使用sa帐号,只有当没有其它方法登录到sqlserver实例(例如,当其它系统管理员不可用或忘记了密码)时才使用sa。建议数据库管理员新建立个拥有与sa一样权限的超级用户来管理数据库。安全的帐号策略还包括不要让管理员权限的帐号泛滥。
sqlserver的认证模式有windows身份认证和混合身份认证两种。如果数据库管理员不希望操作系统管理员来通过操作系统登陆来接触数据库的话,可以在帐号管理中把系统


211



帐号“builtin\administrators”删除。不过这样做的结果是一旦sa帐号忘记密码的话,就没有办法来恢复了。很多主机使用数据库应用只是用来做查询、修改等简单功能的,请根据实际需要分配帐号,并赋予仅仅能够满足应用要求和需要的权限。比如,只要查询功能的,那么就使用一个简单public帐号能够select就可以了。3、加强数据库日志的记录
审核数据库登录事件的“失败和成功”,在实例属性中选择“安全性”,将其中的审核级别选定为全部,这样在数据库系统和操作系统日志里面,就详细记录了所有帐号的登录事件。请定期查看sqlserver日志检查是否有可疑的登录事件发生,或者使用dos命令。findstr/c:"登录"d:\microsoftsqlserver\mssql\log\*.*4、管理扩展存储过程
对存储过程进行大手术,并且对帐号调用扩展存储过程的权限要慎重。其实在多数应用中根本用不到多少系统的存储过程,而sqlserver的这么多系统存储过程只是用来适应广大用户需求的,所以请删除不必要的存储过程,因为有些系统的存储过程能很容易地被人利用起来提升权限或进行破坏。如果你不需要扩展存储过程xp_cmdshell请把它去掉。使用这个sql语句:usemaster


311



sp_dropextendedprocxp_cmdshell
xp_cmdshell是进入操作系统的最佳捷径,是数据库留给操作系统的一个大后门。如果你需要这个存储过程,请用这个语句也可以恢复过来。
sp_addextendedprocxp_cmdshell,xpsql70.dll如果你不需要请丢弃ole自动存储过程(会造成管理器中的某些特征不能使用)这些过程包括如下:
sp_oacreatesp_oadestroysp_oageterrorinfosp_oagetproperty
sp_oamethodsp_oasetpropertysp_oastop
去掉不需要的注册表访问的存储过程,注册表存储过程甚至能够读出操作系统管理员的密码来,如下:
xp_regaddmultistringxp_regdeletekeyxp_regdeletevalue
xp_regenumvaluesxp_regreadxp_regremovemultistringxp_regwrite
还有一些其他的扩展存储过程,你也最好检查检查。在处理存储过程的时候,请确认一下,避免造成对数据库或应


411



用程序的伤害。5、使用协议加密
sqlserver2000使用的tabulardatastream协议来进行网络数据交换,如果不加密的话,所有的网络传输都是明文的,包括密码、数据库内容等等,这是一个很大的安全威胁。能被人在网络中截获到他们需要的东西,包括数据库帐号和密码。所以,在条件容许情况下,最好使用ssl来加密协议,当然,你需要一个证书来支持。
6、不要让人随便探测到你的tcp/ip端口
默认情况下,sqlserver使用1433端口监听,很多人都sqlserver配置的时候要把这个端口改变,这样别人就不能很容易地知道使用的什么端口了。可惜,通过微软未公开1434端口的udp探测可以很容易知道sqlserver使用的什么tcp/ip端口了。不过微软还是考虑到了这个问题,毕竟公开而且开放的端口会引起不必要的麻烦。在实例属性中选择tcp/ip协议的属性。选择隐藏sqlserver实例。如果隐藏了sqlserver实例,则将禁止对试图枚举网络上现有的sqlserver实例的客户端所发出的广播作出响应。这样,别人就不能用1434来探测你的tcp/ip端口了(除非用portscan
7、修改tcp/ip使用的端口
请在上一步配置的基础上,更改原默认的1433端口。


511

本文来源:https://www.2haoxitong.net/k/doc/a0ed0ae668eae009581b6bd97f1922791788bed2.html

《sqlserver数据库安全配置规范.doc》
将本文的Word文档下载到电脑,方便收藏和打印
推荐度:
点击下载文档

文档为doc格式