数据库技术与应用第13章SQLServer安全管理.ppt
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《数据库技术与应用第13章SQLServer安全管理.ppt》由会员分享,可在线阅读,更多相关《数据库技术与应用第13章SQLServer安全管理.ppt(82页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第13章 SQL Server安全管理13.1 SQL Server 2000的安全机制的安全机制13.2 管理服务器的安全性管理服务器的安全性13.3 管理数据库用户管理数据库用户13.4 管管 理理 角角 色色13.5 管管 理理 权权 限限合理有效的数据库安全机制可以既保合理有效的数据库安全机制可以既保证被授权用户能够方便地访问数据库中的证被授权用户能够方便地访问数据库中的数据,又能够防止非法用户的入侵。数据,又能够防止非法用户的入侵。SQLServer2000提供了一套设计完善、操作简提供了一套设计完善、操作简单的安全管理机制。单的安全管理机制。13.1SQLServer2000的安全
2、机制的安全机制SQLServer2000的的安安全全性性机机制制由由四四层层构构成,可以用图成,可以用图13-1表示。表示。从用户的角度讲,要访问数据库,需经过从用户的角度讲,要访问数据库,需经过如下步骤。如下步骤。图图13-1SQLServer2000的安全性机制的安全性机制(1)一个数据库用户必须有权登录操作)一个数据库用户必须有权登录操作系统,即该用户在系统,即该用户在Windows2000Server操操作系统中具有登录账户。在这个前提条件作系统中具有登录账户。在这个前提条件下,才有可能进入下,才有可能进入SQLServer2000系统。系统。(2)一旦登录了操作系统,登录者还必)一旦
3、登录了操作系统,登录者还必须得到数据库系统的通行证须得到数据库系统的通行证数据库服务数据库服务器的登录账户,才具有数据库服务器的连器的登录账户,才具有数据库服务器的连接权或登录权。接权或登录权。SQLServer2000只有在只有在验证了指定的登录账户有效后,才完成连验证了指定的登录账户有效后,才完成连接。这种对登录账户的验证称为身份验证。接。这种对登录账户的验证称为身份验证。对用户而言,登录对用户而言,登录SQLServer2000需要需要使用以下两类身份验证之一。使用以下两类身份验证之一。Windows身份验证:此种验证方式仅用于身份验证:此种验证方式仅用于Windows2000Serve
4、r/NT操作系统。在这操作系统。在这种方式下,用户只要通过种方式下,用户只要通过Windows2000Server/NT操作系统的登录验证,就可以操作系统的登录验证,就可以连接到连接到SQLServer2000数据库实例。数据库实例。SQLServer身份验证:在此种验证方式下,身份验证:在此种验证方式下,即使用户已经登录操作系统,也必须输入即使用户已经登录操作系统,也必须输入有效的有效的SQLServer专用登录名与密码方可专用登录名与密码方可连入连入SQLServer2000数据库实例。数据库实例。(3)当一个登录者登录数据库服务器后,)当一个登录者登录数据库服务器后,并不等于对其中的数据
5、库具有访问权限,并不等于对其中的数据库具有访问权限,还必须由数据库所有者或管理员授权,使还必须由数据库所有者或管理员授权,使该登录者成为某一个数据库的用户。该登录者成为某一个数据库的用户。(4)作为某个数据库的用户,对数据库)作为某个数据库的用户,对数据库对象(如数据库对象(如数据库pubs中的表中的表authors)的访)的访问权限也必须被授予,这些权限包括问权限也必须被授予,这些权限包括SELECT、UPDATE、INSERT、DELETE等。等。另一方面,从另一方面,从SQLServer2000数据库服务数据库服务器的角度讲,对于要登录数据库服务器的器的角度讲,对于要登录数据库服务器的用
6、户,用户,SQLServer2000采用以下两种安全采用以下两种安全认证模式。认证模式。(1)仅)仅Windows认证模式:这是认证模式:这是SQLServer2000的默认身份验证模式,适用于的默认身份验证模式,适用于所有登录者均为所有登录者均为Windows2000Server/NT操作系统用户的情况。但在操作系统用户的情况。但在Windows98操操作系统上运行的作系统上运行的SQLServer实例不支持实例不支持Windows身份验证。身份验证。(2)混合认证模式:该模式可用于两类)混合认证模式:该模式可用于两类登录者,对于登录时提供了登录者,对于登录时提供了SQLServer2000
7、登录账户者,系统将使用登录账户者,系统将使用SQLServer身份验证对其进行验证。对于没有提供身份验证对其进行验证。对于没有提供SQLServer2000登录账户或请求登录账户或请求Windows身份验证的登录者,则使用身份验证的登录者,则使用Windows身份验证对其进行验证。身份验证对其进行验证。13.2管理服务器的安全性管理服务器的安全性对于一个合法的数据库用户,首先必须在对于一个合法的数据库用户,首先必须在SQLServer2000中为其设置相应的登录账户,中为其设置相应的登录账户,否则他不能登录数据库服务器。有两类登录账户,否则他不能登录数据库服务器。有两类登录账户,SQLServ
8、er身份验证的登录账户(以下简称身份验证的登录账户(以下简称SQL账户)与账户)与Windows身份验证的登录账户(以下身份验证的登录账户(以下简称简称Windows账户)。账户)。SQL账户的登录名称与登账户的登录名称与登录密码由录密码由SQLServer2000系统负责验证,系统负责验证,Windows账户的登录名称与登录密码则由账户的登录名称与登录密码则由Windows2000Server/NT负责验证。负责验证。使用企业管理器管理登录账户使用企业管理器管理登录账户只有只有sysadmin或或securityadmin固定固定服务器角色的成员能够利用企业管理器或服务器角色的成员能够利用企
9、业管理器或T-SQL语句完成语句完成SQL账户和账户和Windows账户账户的管理任务。的管理任务。1建立登录账户建立登录账户2登录账户的有关内容登录账户的有关内容3修改登录账户修改登录账户 13.2.2 使用T-SQL语句管理登录账户管管理理登登录录账账户户也也可可以以使使用用T-SQL语语句句,需需要要注注意意的的是是管管理理Windows账账户户与与SQL账账户户所使用的系统存储过程不同。所使用的系统存储过程不同。1管理管理Windows身份验证的身份验证的登录账户登录账户(1)向)向Windows账户授权的语法如下。账户授权的语法如下。命令格式:命令格式:sp_grantloginlo
10、giname=login命令说明:命令说明:loginame=login 指定一个名称为指定一个名称为login的的Windows2000Server/NT用户或用户或用户组名称,其格式为用户组名称,其格式为域域用户名用户名 或或计算机名计算机名用户名用户名,loginame可以省略。可以省略。(2)拒拒绝绝一一个个Windows账账户户登登录录的的语语法法如下。如下。命令格式:命令格式:sp_denyloginloginame=login(3)删除一个)删除一个Windows账户的语法如下。账户的语法如下。命令格式:命令格式:sp_revokeloginloginame=login2管理管理
11、SQL身份验证的登录账户身份验证的登录账户(1)使用系统存储过程创建)使用系统存储过程创建SQL账户账户命令格式:命令格式:sp_addloginloginame=login,passwd=password,defdb=database,deflanguage=language命令说明:命令说明:login为新建登录账户的名称为新建登录账户的名称。password为为密密码码,默默认认设设置置为为NULL。database为登录时的默认数据库。为登录时的默认数据库。language为默认语言为默认语言。全部按上述次序取值时,局部变全部按上述次序取值时,局部变量名称量名称loginame、pas
12、swd、defdb、deflanguage可以省略。可以省略。(2)使使用用系系统统存存储储过过程程修修改改SQL账账户户的密码的密码命令格式:命令格式:sp_password old=old _ password,new=new _password,loginame=login 命令说明:命令说明:(1)old _ password为为旧旧的的登登录录密密码码,其其默认值为默认值为NULL;(2)new _password为新的登录密码,为新的登录密码,无默认值;无默认值;login为需要更改密码的登录名,为需要更改密码的登录名,login必须已经存在。必须已经存在。(3)使使用用系系统统存
13、存储储过过程程修修改改SQL账账户户的的默认数据库默认数据库命令格式:命令格式:sp_defaultdbloginame=login,defdb=database 命命令令说说明明:database是是新新的的默默认认数数据据库库的的名称。名称。(4)使使用用系系统统存存储储过过程程修修改改SQL账账户户的的默认语言默认语言命令格式:命令格式:sp_defaultlanguageloginame=login,deflanguage=language 命令说明:命令说明:language是新的数据库是新的数据库默认语言。默认语言。(5)使用系统存储过程删除)使用系统存储过程删除SQL账户账户命令
14、格式:命令格式:sp_droploginloginame=login 13.2.3 特殊的登录账户特殊的登录账户saSQLServer2000在安装后自动建立在安装后自动建立了一个特殊的了一个特殊的SQL账户账户sa,即,即SystemAdministrator。该账户默认为是所有数据。该账户默认为是所有数据库的库的dbo用户用户(数据库所有者),具有最(数据库所有者),具有最高权限,可以进行任何操作,且不能被删高权限,可以进行任何操作,且不能被删除。刚安装完毕时,除。刚安装完毕时,sa没有密码,为了安没有密码,为了安全起见,一定要为其加入密码。全起见,一定要为其加入密码。13.3管理数据库用
15、户管理数据库用户无论是无论是Windows账户还是账户还是SQL账户,账户,登录数据库服务器后的其他操作都是相同登录数据库服务器后的其他操作都是相同的。但首先他必须获得对数据库的访问权。的。但首先他必须获得对数据库的访问权。SQLServer2000通过为登录账户指派数通过为登录账户指派数据库用户来使其获得对数据库的访问权限。据库用户来使其获得对数据库的访问权限。13.3.1 使使用用企企业业管管理理器器管管理数据库用户理数据库用户1新建数据库用户新建数据库用户2删除数据库用户删除数据库用户13.3.2 使使用用T-SQL语语句句管管理理数数据库用户据库用户使使用用系系统统存存储储过过程程可可
16、以以在在当当前前数数据据库库中中管管理数据库用户。理数据库用户。1新建数据库用户新建数据库用户命令格式:命令格式:sp_grantdbaccess loginame=login,name_in_db=name_in_db命令说明:命令说明:(1)login:为为登登录录账账户户的的登登录录名名,当当其其为为Windows账账户户名名时时,须须采采用用“域域名名登登录录名名”格格式式;当当其其为为SQL账账户户名名时时,采采用用“登录名登录名”格式。格式。(2)name_in_db:表示在当前数据:表示在当前数据库中为该登录账户所指定的数据库用户的库中为该登录账户所指定的数据库用户的用户名,省略
17、该参数,则默认登录名与用用户名,省略该参数,则默认登录名与用户名相同。户名相同。2删除数据库用户删除数据库用户命令格式:命令格式:sp_revokedbaccessname_in_db=name 命令说明:命令说明:name为当前数据库中要为当前数据库中要删除的用户名。删除的用户名。13.3.3 特殊的数据库用户特殊的数据库用户dbo 和和guestSQLServer2000数数据据库库中中有有2个个特特殊殊用用户户:dbo和和guest。1dbo在在创创建建一一个个数数据据库库时时,SQLServer2000自自动动将将创创建建该该数数据据库库的的登登录录账账户户设设置置为为该该数数据据库库
18、的的一一个个用用户户,并并起起名名为为dbo。dbo是是数数据据库库的的拥拥有有者者,不不能能从从数数据据库库中中删删除除,dbo对对本本数数据据库库拥拥有有所所有有操操作作权权限限,并并可可以以将将这这些些权权限限全全部部或或部部分分授授予予其其他他数数据据库库用用户户。另另外外,属属于于固固定定服服务务器器角角色色sysadmin的成员也映射为所有数据库的的成员也映射为所有数据库的dbo。2guest当一个登录者登录数据库服务器时,当一个登录者登录数据库服务器时,如果该服务器上的所有数据库都没有为其如果该服务器上的所有数据库都没有为其建立用户账户,则该登录者只能访问那些建立用户账户,则该登
19、录者只能访问那些具有具有guest用户的数据库。系统数据库用户的数据库。系统数据库Master与与tempdb中的中的guest用户不能被删用户不能被删除除,而其他数据库中的,而其他数据库中的guest用户可以被用户可以被添加或删除。添加或删除。13.4管管理理角角色色角色是为了方便权限管理而设置的一角色是为了方便权限管理而设置的一种管理单位。若打算使一组登录账户或数种管理单位。若打算使一组登录账户或数据库用户在数据库服务器或数据库对象上据库用户在数据库服务器或数据库对象上具有相同的权限,则可以通过角色实现。具有相同的权限,则可以通过角色实现。13.4.1 固定角色固定角色固定角色按其权限作用
20、范围可以分为固定固定角色按其权限作用范围可以分为固定服务器角色与固定数据库角色,其作用范服务器角色与固定数据库角色,其作用范围分别为整个数据库服务器与单个数据库。围分别为整个数据库服务器与单个数据库。这些角色不能修改或删除。这些角色不能修改或删除。1固定服务器角色固定服务器角色SQLServer2000的服务器角色只有固定服的服务器角色只有固定服务器角色,用于对数据库服务器的操作。务器角色,用于对数据库服务器的操作。对数据库服务器操作的权限不能直接赋给对数据库服务器操作的权限不能直接赋给其他登录账户,只能使某些登录账户成为其他登录账户,只能使某些登录账户成为固定服务器角色的成员,才能使他们具有
21、固定服务器角色的成员,才能使他们具有这些权限。这些权限。SQLServer2000具有如下固定具有如下固定服务器角色:服务器角色:(1)sysadmin,有权在,有权在SQLServer中进中进行任何活动。行任何活动。(2)serveradmin,有权设置服务器一级,有权设置服务器一级的配置选项,关闭服务器。的配置选项,关闭服务器。(3)setupadmin,有权管理链接服务器,有权管理链接服务器和启动过程。和启动过程。(4)securityadmin,有权管理登录和,有权管理登录和CREATEDATABASE权限,还可以读取权限,还可以读取错误日志和更改密码。错误日志和更改密码。(5)pro
22、cessadmin,有权管理在,有权管理在SQLServer中运行的进程。中运行的进程。(6)dbcreator,有权创建、更改和除去,有权创建、更改和除去数据库。数据库。(7)diskadmin,有权管理磁盘文件有权管理磁盘文件。(8)bulkadmin,有权执行,有权执行BULKINSERT语句。语句。2固定数据库角色固定数据库角色SQLServer2000中的数据库角色用于对单中的数据库角色用于对单个数据库的操作。每个数据库都有一系列个数据库的操作。每个数据库都有一系列固定数据库角色,尽管在不同的数据库内固定数据库角色,尽管在不同的数据库内他们是同名的,但各自的作用范围都仅限他们是同名的
23、,但各自的作用范围都仅限于本数据库。于本数据库。SQLServer2000具有如下固具有如下固定数据库角色:定数据库角色:(1)db_owner,在数据库中具有全部权,在数据库中具有全部权限。限。(2)db_accessadmin,有权添加或删除数,有权添加或删除数据库用户。据库用户。(3)db_securityadmin,有权管理全部权,有权管理全部权限、对象所有权、角色和角色成员资格。限、对象所有权、角色和角色成员资格。(4)db_ddladmin,有权发出,有权发出ALLDDL,但不能发出,但不能发出GRANT、REVOKE或或DENY语句。语句。(5)db_backupoperator
24、,有权发出,有权发出DBCC、CHECKPOINT和和BACKUP语语句。句。(6)db_datareader,有权查询数据库内,有权查询数据库内任何用户表中的所有数据。任何用户表中的所有数据。(7)db_datawriter,有权更改数据库内,有权更改数据库内任何用户表中的所有数据。任何用户表中的所有数据。(8)db_denydatareader,不能查询数据,不能查询数据库内任何用户表中的任何数据。库内任何用户表中的任何数据。(9)db_denydatawriter,不能更改,不能更改数据库内任何用户表中的任何数据。数据库内任何用户表中的任何数据。13.4.2 用户定义的数据库角色用户定义
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库技术 应用 13 SQLServer 安全管理
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内