构建免受FSO组件威胁虚拟主机
现在绝大多数的虚拟主机都禁用了 asp 的标准:filesystemobject,因为这个组件为 asp 提供了强大的文件访问能力,可以对服务器硬盘上的任何文件进行读、写、复制、删除、改名等操作(当然,这是指在使用默认设置的 windows nt / 2000 下才能做到)。但是禁止此组件后,引起的后果就是所有利用这个组件的 asp 将无法运行,无法满足客户的需求。
如何既允许 filesystemobject 组件,又不影响服务器的安全性(即:不同虚拟主机用户之间不能使用该组件读写别人的文件)呢?这里介绍本人在实验中获得的一种方法,下文以 windows 2000 server 为例来说明。
在服务器上打开资源管理器,用鼠标右键点击各个硬盘分区或卷的盘符,在弹出菜单中选择“属性”,选择“安全”选项卡,此时就可以看到有哪些帐号可以访问这个分区(卷)及访问权限。默认安装后,出现的是“everyone”具有完全控制的权限。点“添加”,将“administrators”、“backup operators”、“power users”、“users”等几个组添加进去,并给予“完全控制”或相应的权限,注意,不要给“guests”组、“iusr_机器名”这几个帐号任何权限。然后将“everyone”组从列表中删除,这样,就只有授权的组和用户才能访问此硬盘分区了,而 asp 执行时,是以“iusr_机器名”的身份访问硬盘的,这里没给该用户帐号权限,asp 也就不能读写硬盘上的文件了。
下面要做的就是给每个虚拟主机用户设置一个单独的用户帐号,然后再给每个帐号分配一个允许其完全控制的目录。
如下图所示,打开“计算机管理”→“本地用户和组”→“用户”,在右栏中点击鼠标右键,在弹出的菜单中选择“新用户”:
520)this.width=520" border=0 dypop="按此在新窗口浏览图片">
在弹出的“新用户”对话框中根据实际需要输入“用户名”、“全名”、“描述”、“密码”、“确认密码”,并将“用户下次登录时须更改密码”前的对号去掉,选中“用户不能更改密码”和“密码永不过期”。本例是给第一虚拟主机的用户建立一个匿名访问 internet 信息服务的内置帐号“iusr_vhost1”,即:所有客户端使用 访问此虚拟主机时,都是以这个身份来访问的。输入完成后点“创建”即可。可以根据实际需要,创建多个用户,创建完毕后点“关闭”:
520)this.width=520" border=0>
现在新建立的用户已经出现在帐号列表中了,在列表中双击该帐号,以便进一步进行设置:
520)this.width=520" border=0 dypop="按此在新窗口浏览图片">
在弹出的“iusr_vhost1”(即刚才创建的新帐号)属性对话框中点“隶属于”选项卡:
520)this.width=520" border=0 dypop="按此在新窗口浏览图片">
刚建立的帐号默认是属于“users”组,选中该组,点“删除”:
520)this.width=520" border=0 dypop="按此在新窗口浏览图片">
现在出现的是如下图所示,此时再点“添加”:
520)this.width=520" border=0 dypop="按此在新窗口浏览图片">
在弹出的“选择 组”对话框中找到“guests”,点“添加”,此组就会出现在下方的文本框中,然后点“确定”:[www.knowsky.com]
520)this.width=520" border=0 dypop="按此在新窗口浏览图片">
出现的就是如下图所示的内容,点“确定”关闭此对话框:
520)this.width=520" border=0>
打开“internet 信息服务”,开始对虚拟主机进行设置,本例中的以对“第一虚拟主机”设置为例进行说明,右击该主机名,在弹出的菜单中选择“属性”:
520)this.width=520" border=0 dypop="按此在新窗口浏览图片">
弹出一个“第一虚拟主机 属性”的对话框,从对话框中可以看到该虚拟主机用户的使用的是“f:vhost1”这个文件夹:
520)this.width=520" border=0 dypop="按此在新窗口浏览图片">