sql server、internet 信息服务器和 asp.net 引擎都提供了坚实可靠的安全模型,它们可以很好地在一起协同工作。为了保证用户数据和应用程序的安全,microsoft 还为每项服务的默认设置设置了相当低的值。大多数开发人员面临的挑战是如何使用 sql server、iis 和 asp.net 在应用程序和数据之间设置适当的信任级别,而不会留下可被别人轻易攻入的安全漏洞。由于涉及三类服务(sql server、iis 和 asp.net),所以需要采取三个关键的步骤来确保解决方案的安全。本部分讨论一种为 web 应用程序设置足够权限和信任级别的更常用(且可靠)的方法。
注意:关于安全性和 web 解决方案这个大主题,本系列文章难以展开较充分的讨论。要更好地理解此问题和可能的解决方案,请参阅安全 asp.net 应用程序的创建模式和实践系列文章:验证、授权和安全通信。 定义 dotnetkb 自定义 iis 用户帐户。
保证 web 应用程序安全性的最安全的方法是定义一个权限有限的自定义用户,然后对 iis 进行配置,使之能够在执行您的 web 应用程序时能作为自定义用户运行。这是相当容易实现的,可以确保访问您的 web 应用程序的每个访问者都只具有您希望他们具有的权限。
第一步是生成一个新的 windows 用户(本例中称为 dotnetkb),为其设置一个增强型密码,然后将其添加到 windows 来宾组 (guest windows group) 中。同时,确保选中 password never expires(密码永不过期)和 user cannot change password(用户不能更改密码)复选框。这样将生成一个权限有限的用户,在 iis 中运行您的 web 应用程序时,您可以将其用作标识(参见图 7)。
图 7:生成的权限有限的用户
然后,调用 internet 信息服务器管理员并选择承载这些网页的 web 应用程序。在本例中,您可以选择承载前文所生成的测试页的 web 应用程序 (dotnetkb_website)。在树视图中的 web 应用程序上单击鼠标右键,然后从上下文相关菜单中选择 properties...(属性...)。然后选择 directory security(目录安全性)并单击该对话框 anonymous access and authentication control(匿名访问和验证控制)部分中的 edit(编辑)按钮。最后,输入自定义用户名 (dotnetkb),取消选择 allow iis to control password(允许 iis 控制密码)复选框,并输入该自定义用户帐户的密码。完成所有这些工作之后,单击 ok(确定)按钮,将这些更改保存到 iis 配置数据库中(参见图 8)。
然后,您需要为该自定义用户授予访问数据库 (dotnetkb) 的相应权限。为此,您可以使用 microsoft sql server 企业管理器或编写一个自定义脚本,以创建一个这样的用户并授予其访问特定对象的权限。本文介绍如何使用 sql server 企业管理器完成此操作。您还可以从后文中看到一个脚本示例。
注意:尽管 visual studio .net 2003 具有与 sql server 兼容的许多强大的集成功能,但也不允许从 visual studio .net 2003 中轻松管理用户和用户权限。在大型的组织和团队中,这些高级任务通常由数据库管理员完成。
因此,启动 sql server 企业管理器之后,您可以按照以下步骤将自定义用户 (dotnetkb) 添加数据库中(参见图 9):
在左侧的树视图中,展开节点以显示 dotnetkb 数据库。在我的计算机上,树视图的结构如下:console root | sql server group | (local) (windows nt) | databases | dotnetkb。 然后,在数据库下的 users(用户)节点上单击鼠标右键,并选择 new database user...(新建数据库用户...)。显示 database user properties - new user(数据库用户属性 - 新建用户)对话框时,从 login name(登录名)下拉框中选择 <new>(<新建>)。
显示 sql server login properties - new login(sql server 登录属性 - 新建登录)对话框时,选择 general(常规)选项卡,并在 name(名称)输入框中输入 dotnetkb。确保选中 windows authentication(windows 验证)单选按钮,并从 domain(域)下拉框中选择自定义用户帐户所在的计算机的名称。然后从 database(数据库)下拉框中选择 dotnetkb。 现在,选择 databases(数据库)选项卡,在对话框顶部的列表中找到 dotnetkb 数据库并选中它。然后,确保选中对话框底部列表中的 public(公共)角色。最后,单击对话框底部的 ok(确定)按钮,保存您的更改。