网安(3)——MSSQL数据库安全实验

   管理SQL Server认证模式

 (1)确认 SQL Server 验证

    ①在桌面上单击“开始”,选择“程序”→“Microsoft SQL Server 2005” →“SQL Server Management Studio”,出现“连接到服务器”对话框。

    ②在“连接到服务器”对话框中,按表中的指定值进行设置,然后单击“连接”按钮,如下图。

 

③如果“对象资源管理器”不可见,则选择“视图”菜单上的“对象资源管理器”。

    ④在“对象资源管理器”中,右击服务器,然后单击“属性”。   

    ⑤单击“安全性”。

 

    ⑥在“服务器身份验证”选项区中,可以选择身份验证模式,“Windows 身份验证模式”或“SQL Server 和Windows 身份验证模式”,本次实验选择“SQL Server 和Windows 身份验证模式”。

    

    在“摘要”面板中,右击“SQL Server 代理”,然后单击“启动”。

    

管理数据库登录

    (1)使用企业管理器管理Windows身份验证的登录帐号。

    ① 回到桌面,右击我的电脑,点击管理。

    然后一次展开系统工具-本地用户和组-用户,此时在右边可以看到当前系统中所有的用户。

    

   在右侧空白处右击,点击新用户。  

    添加一个用户WinUser,并给该用户设置一个密码,本实验使用的密码是admin,密码可随意设置,但是需要记住,在后面需要用到,把用户下次登录时须更改密码前面的勾选去掉,把密码永不过期的选项选上,然后点击创建,设置如图:

    

  创建完后点击关闭。

    然后右击该用户,选择属性。

    

    弹出如下对话框:

    

    点击隶属于选项卡。

    

    然后点击左下角的添加按钮。弹出选择组对话框。

    

   点击左下角的高级,弹出如下对话框:

    

    点击立即查找,在搜索结果中选择 administrators。

    

    然后点击确定按钮,会自动返回上一回话窗口。

    

    同样点击确定。此时,在winuser属性的隶属于选项卡下可以看到,多了一个administrators。

    

    然后点击右下角的应用,最后点击确定。

    ②在SQL Server Management Studio中,右击数据库,选择新建数据库

    

 

 

  在数据库名称内输入student新建一个student数据库,然后点击确定 。  

    展开实例下的“安全性”,右击“登录名”按钮,在弹出的快捷菜单中选择“新建登录”。

   

打开SQL Server登录属性对话框。在“常规”选项卡中,单击“名称”输入框右侧的按钮。

    

    弹出选择用户或组对话框

    

  点击高级,弹出新的对话框  

    点击右侧的立即查找,在搜索结果中,找到winuser并选择该用户,然后点击确定。

    

    会自动返回上一个对话框,然后点击确定。

    

    验证方式选择 “Windows 身份验证”。

    默认数据库选择student,完成登陆账号winuser的创建。

    

    ③选择“服务器角色”选项卡。可以在服务器角色列表框中选择相应的服务器角色成员。在这里,设置登录用户winuser的服务器角色为系统管理员。

    

    ④选择“用户映射”选项卡,在列表框中列出了该账号可以访问的数据库,如果单击数据库左边的复选框,表示该用户可以访问相应的数据库。在这里,选中数据库master和student左边的复选框,表示登陆用户winuser可以访问的数据库为master和student。在下方的数据库角色成员身份都选择public。然后点击确定。

    

   在对象资源管理器中,展开安全性-登录名,可以看到winuser已存在。

    

    同时,展开数据库-系统数据库-student-安全性-用户,在用户列表中可以看到数据库student中已经建立一个数据库用户winuser。

    验证用WinUser账号登录SQL Server:首先在操作系统中注销当前用户的登陆,将用户切换到WinUser,再用此账号连接SQL Server查询分析器,用Windows身份验证登录,可以进入查询分析器,使用数据库master和student。

    由于远程桌面注销会又会自动连接,所以我们需要先修改当前用户(administrator)的登录密码。

    来到桌面,右击我的电脑,点击管理,在计算机管理窗口,依次展开 系统工具-本地用户和组-用户(不会的可参考之前新建winuser时的步骤),在右侧右击administrator,选择设置密码。

    

    会弹出如下对话框,点击继续。

    

    然后设置一个密码(我设置的密码是admin),可以随意设置,但是需要记住密码,后面还需要登陆该用户。

    

 点击确定,会提示密码已设置

    

    然后点击左下角的开始,选择注销

    

    弹出确认窗口,点击注销。

    然后会自动到登陆页面,输入之前新建的winuser和密码,点击确定登录。

    

    登录后,点击左下角的开始-所有程序-Microsoft SQL Server 2005-SQL Server Management Studio 进入SQL Server Management Studio。

    

    身份验证选择 Windows 身份验证。

    

    点击连接后,登陆成功,此时可以新建查询,使用数据库master和student。

    (2)使用SQL Server Management Studio管理SQL Server身份验证的登录帐号。

    注销winuser,切换到administrator用户(不会的可参考之前从administrator切换到winuser的步骤)。

    ①在 SQL Server Management Studio中,展开实例下的“安全性”,右击“登录名”按钮,在弹出的快捷菜单中选择“新建登录”(参考前面新建登录步骤),

    ②在登录名输入框内输入需要新建的用户名,这里新建的用户名是SQLUser。验证方式选择SQL Server身份验证,然后在密码框输入SQLUser的密码。这里设置成test。把强制实施密码策略的复选框去勾选去掉,默认数据库选择master,然后点击确认。

    

    注意:采用该方法创建的SQL Server登录账号只能用于登录SQL Server服务,与登录的计算机的Windows账号无关,不能用此账号登录Windows。

    ③单击“用户映射”,在“映射到此用登录名的用户”中,将所有数据库都选中,下方的数据库角色成员身份全部选择public,然后单击确定完成账号的创建。

    

 

    ④关闭SQL Server Management Studio重新打开,在登录页面处身份验证选择SQL Server身份验证。然后输入刚才新建的账号和密码,然后点击连接。

    

    登录成功,此时可以新建查询来查询数据。

实验步骤三

    管理数据库用户

    数据库用户对数据的访问权限以及对数据库对象的所有关系都是通过用户账号来控制的。在数据库中,用户账号与登录账号是两个不同的概念。一个合法的登录账号只表明该账号通过了Windows认证或SQL Server 认证,但不能表明其可以对数据库数据和数据对象进行某种或某些操作,只有其同时拥有了用户账号后,才能够访问数据库。所以一个登录账号总是与一个或多个数据库用户账号(这些账号必须分别存在相异的数据库中)相对应,这样才可以访问数据库。

    (1)创建数据库用户

    打开SQL Server Management Studio,展开服务器-数据库,选择要创建用户的数据库,如student,展开student,用鼠标右键单击“安全性”节点,从弹出的菜单中选择“新建-用户”命令。

    弹出“新建用户”对话框,在用户名输入框输入要新建的数据库用户名称,如dbuser

    

    在“登录名”处点击后面的按钮

    弹出选择登录名对话框,在该对话框选择浏览

    

    弹出查找对象对话框,在里面选择一个用户,选择administrators。

    

    然后点击确定,自动返回到选择登录名对话框

    

 点击确定,在此用户拥有的架构勾选db_owner,数据库角色成员身份同样选择db_owner,单击“确定”按钮,即可完成数据库用户的创建。

    

    (2)修改用户信息

    用鼠标右键单击要修改的用户,在系统弹出菜单上单击“属性”

    

    可打开“数据库用户”对话框查看该用户的信息,同时需要时能直接修改相应用户的设置信息。

    

    (3)删除数据库用户。

    在企业管理器中,用鼠标右键单击要删除的数据库用户,如数据库student中的数据库用户dbuser,从快捷菜单中选择“删除”命令即可。

    

    管理数据库角色

    SQL Server有自己的固有角色。固有角色是指 SQL Server预先定义好的系统角色。用户不能修改这些角色的任何属性,也不能创建新的服务器固有角色和数据库固有角色。

    数据库角色是在数据库的安全级别上创建,一个数据库角色只在其所在的数据库中有效,对其他数据库无效。在数据库中,除了有固有的数据库角色外,还可以自定义数据库角色,同时根据需要,可以为数据库角色添加成员或删除自定义角色。

    1.创建数据库角色

    打开SQL Server Management Studio,展开服务器-数据库,选择要创建用户的数据库,如student,展开student,用鼠标右键单击“安全性”节点,从弹出的菜单中选择“新建-数据库角色”命令。

    

    弹出“新建角色”对话框,在角色名称输入框中输入数据库新角色的名称,如NewRole,点击所有者后面的按钮

    

    在里面选择一个用户,例如选择winuser(如果不会,参考前面的步骤)

    

    在此角色拥有的架构中选择db_owner,然后点击确定,完成角色创建。

    

 

    可以在安全性-角色-数据库角色中看到,刚才添加的角色已经成功。

   

    (2)删除自定义的数据库角色

    在SQL Server Management Studio中,用鼠标右键单击要删除的自定义角色,如NewRole,从弹出的菜单中选择“删除”命令即可删除自定义角色。

    

    管理数据库权限

    权限用来指定授权用户可以使用的数据库对象和这些授权用户可以对这些数据库对象执行的操作。用户在登录到SQL Server之后,其用户账号所归属的NT组或角色所被赋予的权限决定了该用户能够对哪些数据库对象执行哪种操作以及能够访问、修改哪些数据。在SQL Server中包括语句级权限和对象级权限。

    (1)进行语句级权限管理:

    启动SQL Server Management Studio,展开实例数据库,右击student数据库,在弹出的快捷菜单中选择“属性”,然后选择“权限”选项卡。在用户WinUser一栏中,将“创建表”和“创建视图”选中.

    

  在SQLUser一栏中,则选择除“创建表”和“创建视图”以外的选项

    

    图中权限设置的方法是:

    许可权限中复选框单击为勾号时:表示授予该权限。

    许可权限中复选框单击为叉号时:表示角色或用户不具有该操作权限。

    许可权限中复选框既没勾号,也没叉号时:表示角色或用户是否具有该操作权限要根据隐含规则来决定。

    这样的结果是,授予用户WinUser可以在数据库student中创建视图和表。授予用户SQLUser可以在数据库student中进行除创建视图和表以外的所有操作。

思考与分析

1、 SQL Server的Windows认证模式和混合认证模式的区别?

答:两个验证方式的不同主要集中在信任连接和非信任连接。windows 身份验证相对于混合模式更加安全,使用本连接模式时候,sql不推断sapassword。而仅依据用户的windows权限来进行身份验证,我们称为“信任连接”。可是在远程连接的时候会因NTML验证(NT系统一种验证方法)的缘故,无法登陆。 混合模式验证就比較既当本地用户訪问sql时候採用windows身份验证建立信任连接。当远程用户訪问时因为未通过windows认证,而进行sql server认证(使用sa的用户也能够登录sql),建立“非信任连接”。从而使得远程用户也能够登录。 更加直接一些就是windows身份验证。不验证sapassword,假设windows登录password不对,无法訪问sql。混合模式既能够使用windows身份验证登录。有能够在远程使用sapassword登录。  准确来说,混合身份验证模式,也就是基于Windows身份验证和SQL Server身份混合验证。在这个模式中,系统会推断账号在Windows操作系统下是否可信。对于可信连接,系统直接採用Windows身份验证机制。而非可信连接,这个连接不仅包含远程用户还包含本地用户,SQL Server 会自己主动通过账户的存在性和password的匹配性来进行验证。比方当SQL Server实例在Windows 98上执行时,必须使用混合模式,由于在Windows 98上不支持Windows身份验证模式。

2、 分析数据库各种角色权限的异同,自定义数据库,并进行权限管理,深入理解实验原理。

答:db_owner 在数据库中有全部权限。

db_accessadmin 可以添加或删除用户 ID。
db_securityadmin 可以管理全部权限、对象所有权、角色和角色成员资格。
db_ddladmin 可以发出 ALL DDL,但不能发出 GRANT、REVOKE 或 DENY 语句。
db_backupoperator 可以发出 DBCC、CHECKPOINT 和 BACKUP 语句。
db_datareader 可以选择数据库内任何用户表中的所有数据。
db_datawriter 可以更改数据库内任何用户表中的所有数据。
db_denydatareader 不能选择数据库内任何用户表中的任何数据。
db_denydatawriter 不能更改数据库内任何用户表中的任何数据。

3、 查阅近期数据库安全事件,分析攻击原理,掌握数据库安全的重要性

答:Oracle 的广告技术部门,因服务器处于不安全且未设置密码的状态,导致数据库中全球数十亿人的记录被泄露。

Oracle 于 2014 年以超过 4 亿美元的价格收购了初创企业 BlueKai ,并将其产品添加到 Oracle 的数据云(ODC)和营销云(OMC)中。BlueKai 通过 cookie 和其他跟踪技术监视网络上的用户,并为第三方提供数据收集服务,同时维护着一个大型数据库。因为背后有 Oracle 的支撑,BlueKai 的发展相当迅速。据 Whotracks 网站估计,BlueKai 跟踪了所有 Web 流量的 1%以上。但在相当长的一段时期内,保存这些数据的服务器压根没有设置密码,导致网络跟踪数据被全面泄露在公开互联网上。其中的数十亿条记录,随时可供任何人翻阅查看

曝光出来的这些记录,显示出极高的透明度,包含姓名、家庭住址、电子邮件和其他比如付款交易等个人信息,因此通过用户的“数字画像”可以长期追踪他的在线活动。

例如其中一条记录,可以具体到某德国男子(这里隐去真实姓名)曾在 4 月 19 号在电子竞技博彩网站上购买了 10 欧元的注码,还包含该男子的居住地址、电话号码与电子邮件地址。另一条记录显示,一位住在伊斯坦布尔的用户曾在一家家居用品商店在线购买了价值 899 美元的家具,内含买家的详细信息,包括真实姓名、电子邮件地址以及买家订单的网络链接等。安全研究员 Anurag Sen 发现了该数据库,并向 Oracle 方面报告了自己的发现。随后 Oracle 将数据库进行了脱机处理。但不管怎么样,此次曝光数据库的庞大规模都使其成为今年发生的最大安全违规事件之一。

答题

 

 

 

 

 

 

 

posted @ 2021-09-18 00:43  Amerfi1  阅读(102)  评论(0)    收藏  举报