日期:2011-10-31  浏览次数:21213 次

asp 应用程序的安全

千万不要轻视正确配置安全设置的重要性。如果不正确配置安全设置,不但会使您的 asp 应用程序遭受不必要的篡改,而且会妨碍正当用户访问您的 .asp 文件。

web 服务器提供了各种方法来保护您的 asp 应用程序免受未授权的访问和篡改。在您读完本主题下的安全信息之后,请花一定的时间仔细检查一下您的 windows nt 和 web 服务器安全性文档。详细信息,请参阅 安全性。

---ntfs 权限

您可以通过为单独的文件和目录应用 ntfs 访问权限来保护 asp 应用程序文件。ntfs 权限是 web 服务器安全性的基础,它定义了一个或一组用户访问文件和目录的不同级别。当拥有 windows nt 有效帐号的用户试图访问一个有权限限制的文件时,计算机将检查文件的 访问控制表 (acl)。该表定义了不同用户和用户组所被赋予的权限。如果用户的帐号具有打开文件的权限,计算机则允许该用户访问文件。例如,web 服务器上的 web 应用程序的所有者需要有“更改”权限来查看、更改和删除应用程序的 .asp 文件。但是,访问该应用程序的公共用户应仅被授予“只读”权限,以便将其限制为只能查看而不能更改应用程序的 web 页。

---维护 global.asa 的安全

为了充分保护 asp 应用程序,一定要在应用程序的 global.asa 文件上为适当的用户或用户组设置 ntfs 文件权限。如果 global.asa 包含向浏览器返回信息的命令而您没有保护 global.asa 文件,则信息将被返回给浏览器,即便应用程序的其他文件被保护。有关配置 ntfs 权限的详细信息,请参阅 访问控制。

注意: 一定要对应用程序的文件应用统一的 ntfs 权限。例如,如果您不小心过度限制了一应用程序需要包含的文件的 ntfs 权限,则用户可能无法查看或运行该应用程序。为了防止此类问题,在为您的应用程序分配 ntfs 权限之前应仔细计划。

---web 服务器权限

您可以通过配置您的 web 服务器的权限来限制所有用户查看、运行和操作您的 asp 页的方式。不同于 ntfs 权限提供的控制特定用户对应用程序文件和目录的访问方式, web 服务器权限应用于所有用户,并且不区分用户帐号的类型。

对于要运行您的 asp 应用程序的用户,在设置 web 服务器权限时,必须遵循下列原则:

对包含 .asp 文件的虚拟目录允许“读”或“脚本”权限。对 .asp 文件和其他包含脚本的文件(如 .htm 文件等)所在的虚目录允许“读”和“脚本”权限。对包含 .asp 文件和其他需要“执行”权限才能运行的文件(如 .exe和 .dll 文件等)的虚目录允许“读”和“执行”权限。有关配置 web 服务器权限的详细信息,请参阅 访问控制。

---脚本映射文件

应用程序的脚本映射保证了 web 服务器不会意外地下载 .asp 文件的源代码。例如,即使您为包含了某个 .asp 文件的目录设置了“读”权限,只要该 .asp 文件隶属于某个脚本映射应用程序,那么您的 web 服务器就不会将该文件的源代码返回给用户。

---cookie 安全性

asp 使用 sessionid cookie 跟踪应用程序访问或会话期间特定的 web 浏览器的信息。这就是说,带有相应的cookie 的 http 请求被认为是来自同一 web 浏览器。web 服务器可以使用 sessionid cookies 配置带有用户特定会话信息的 asp 应用程序。例如,如果您的应用程序是一个允许用户选择和购买 cd 唱盘的联机音乐商店,就可以用sessionid 跟踪用户漫游整个应用程序时的选择。

---sessionid 能否被黑客猜中?

为了防止计算机黑客猜中 sessionid cookie 并获得对合法用户的会话变量的访问,web 服务器为每个 sessionid 指派一个随机生成号码。每当用户的 web 浏览器返回一个 sessionid cookie 时,服务器取出 sessionid 和被赋予的数字,接着检查是否与存储在服务器上的生成号码一致。若两个号码一致,将允许用户访问会话变量。这一技术的有效性在于被赋予的数字的长度(64 位),此长度使计算机黑客猜中 sessionid 从而窃取用户的活动会话的可能性几乎为 0。

---加密重要的 sessionid cookie

截获了用户 sessionid cookie 的计算机黑客可以使用此 cookie 假冒该用户。如果 asp 应用程序包含私人信息,信用卡或银行帐户号码,拥有窃取的 cookie 的计算机黑客就可以在应用程序中开始一个活动会话并获取这些信息。您可以通过对您的 web 服务器和用户的浏览器间的通讯链路加密来防止 sessionid cookie 被截获。有关加密的详细信息,请参阅 安全性。

---使用身份验证机制保护被限制的 asp 内容

您可以要求每个试图访问被限制的 asp 内容的用户必须要有有效的 windows nt 帐号的用户名和密码。每当用户试图访问被限制的内容时,web 服务器将进行身份验证,即确认用户身份,以检查用户是否拥有有效的 windows nt 帐号。

web 服务器支持以下几种身份验证方式:

基本身份验证 提示用户输入用户名和密码。windows nt 请求/响应式身份验证 从用户的 web 浏览器通过加密方式获取用户身份信息。

然而,web 服务器仅当禁止匿名访问或 windows nt 文件系统的权限限制匿名访问时才验证用户身份。详细信息,请参阅 关于身份验证。

[1] [2] [3] [4] 下一页