现在绝大多数的虚拟主机都禁用了 asp 的标准组件:filesystemobject,因为这个组件为 asp 提供了强大的文件系统访问能力,可以对服务器硬盘上的任何文件进行读、写、复制、删除、改名等操作(当然,这是指在使用默认设置的 windows nt / 2000 下才能做到)。但是禁止此组件后,引起的后果就是所有利用这个组件的 asp 将无法运行,无法满足客户的需求。
如何既允许 filesystemobject 组件,又不影响服务器的安全性(即:不同虚拟主机用户之间不能使用该组件读写别人的文件)呢?这里介绍本人在实验中获得的一种方法,下文以 windows 2000 server 为例来说明。
在服务器上打开资源管理器,用鼠标右键点击各个硬盘分区或卷的盘符,在弹出菜单中选择“属性”,选择“安全”选项卡,此时就可以看到有哪些帐号可以访问这个分区(卷)及访问权限。默认安装后,出现的是“everyone”具有完全控制的权限。点“添加”,将“administrators”、“backup operators”、“power users”、“users”等几个组添加进去,并给予“完全控制”或相应的权限,注意,不要给“guests”组、“iusr_机器名”这几个帐号任何权限。然后将“everyone”组从列表中删除,这样,就只有授权的组和用户才能访问此硬盘分区了,而 asp 执行时,是以“iusr_机器名”的身份访问硬盘的,这里没给该用户帐号权限,asp 也就不能读写硬盘上的文件了。
下面要做的就是给每个虚拟主机用户设置一个单独的用户帐号,然后再给每个帐号分配一个允许其完全控制的目录。
如下图所示,打开“计算机管理”→“本地用户和组”→“用户”,在右栏中点击鼠标右键,在弹出的菜单中选择“新用户”: