.Net中如何操作IIS的原理分析

news/2024/7/10 5:09:57 标签: iis, .net, properties, schema, image, path

 2008-07-11 09:07:36   IT专家网论坛   
  .Net 中实际上已经为我们在这方面做得很好了。FCL中提供了不少的类来帮助我们完成这项工作,让我们的开发工作变非常简单和快乐。编程控制IIS实际上很简单,和ASP一样,.Net中需要使用ADSI来操作IIS,但是此时我们不再需要GetObject这个东东了,因为.Net为我们提供了更加强大功能的新东东。

System.DirectoryServices命名空间中包括了些强大的东东--DirectoryEntry, DirectoryEntries,它们为我们提供了访问活动目录的强大功能,在这些类允许我们操作IIS、LDAP、NDS以及WinNT,功能很强大的吧:)

不过我们此处只谈IIS的控制,一般来说,我们操作IIS一般都是对虚拟目录的操作,因此我将此列为主要的内容来讲。

首先我们要搞清楚IIS的层次结构的问题,下面是我从国外找来的一张图,很好的解释了IIS的层次结构:

[htmChina:Image id=Image112][/htmChina:Image]

为了搞清楚IIS的控制语法,我们就必须搞清上图,了解IIS元数据(Metabase)的层次结构。图中的每一个节点称之Key,而每个Key可以包含一个或多个值,这些值就是我们说的属性 (properties),IIS元数据中的Key与IIS中的元素是相符的,因此元数据中的属性值的设定是会影响IIS中的设置。这就是我们编程的基本思路和核心。

另外还要了解一下Schema这个概念。它表示IIS中构架的名称,即可以理解IIS元数据中Key的类型,具体点说就是指每个结点的类型。我们知道,IIS中有虚拟目录,普通目录,以及文件这些东东,而这些都属于IIS的元素,区分的他们的标帜就是Schema。比如虚拟目录的Schema就是 "IIsVirtualDir",普通目录就是"IIsWebDir"。这样我们添加、删除目录时,IIS就知道我们添加的是虚拟目录还是普通目录。

创建虚拟目录

DirectoryEntry是.Net给我们的一大礼物,他的名字我们就知道他的功能--目录入口。使用过ADSI的人都知道操作IIS,WinNT这些时,我们还需要提供他们的Path,操作IIS时,这个Path的格式为:

IIS://ComputerName/Service/Website/Directory

ComputerName:即操作的服务器的名字,可以是名字也可以是IP,经常用的就是localhost

Service:即操作的服务器,IIS中有Web,也有FTP,还有SMTP这些服务,我们主要是操作IIS的Web功能,因此此处就是"W3SVC",如果是FTP则应是"MSFTPSVC"

WebSite:一个IIS服务中可以包括很多的站点,这个就用于设置操作的站点。他的值是一个数字,默认是1,表示缺省站点,如果有其它,则从1开始依次类推。

Directory:不用说,即操作的目录名称,一个站点一般顶层目录为"ROOT",其它目录则是他的孩子(Child)。

首先我们获取一个站点的顶层目录(根目录):

DirectoryEntry rootfolder = new DirectoryEntry("IIS://localhost/W3SVC/1/ROOT");

如果我们创建这个对象是没有发生异常,则表示这个目录是真实存在的。

下面我们来添加新的虚拟目录,比如我们要加的是"Aspcn":

DirectoryEntry newVirDir = rootfolder.Children.Add("Aspcn","IIsWebVirtualDir");

newVirDir.Invoke("AppCreate",true);

newVirDir.CommitChanges();

rootfolder.CommitChanges();

创建目录的思路很简单,即在根目录的子集(rootfolder.Children)中再添加一条记录,这里使用的是 DirectoryEntries类中的Add方法,它返回的是一个DirectoryEntry,表示新加入的目录,第一个参数是虚拟目录的名字,第二个则是Schema的类名以表明我们加入的目录类型。然后再使用DirectoryEntry的Invoke方法,调用ADSI中的 "AppCreate"方法将目录真正创建(似乎不走这一步也可以创建目录成功,但是为了保险起见,大家还是用吧),最后便是依次调用新、根目录的 CommitChanges方法,确认此次操作。

在创建新目录时,我们也可以同时给这个目录的属性赋值,但是我的实战经验告诉我,最好不要这样做,如果创建时就赋值,将有很多属性不能赋值成功,比如重要的表示真实目录的Path属性。因此飞刀建议大家最好是先创建目录,然后再赋值,即更新目录信息。

更新虚拟目录

相信大家对IIS都比较熟悉,了解IIS中一些重要的设置,如可读(AccessRead)、可写(AccessWrite)、可执行(AccessExecute)等。这些都可通过对DirectoryEntry的Properties属性集合的赋值来实现。赋值可以通过两种方式来完成:

第一种是调用Properties集合的Add方法,如:

dir.Properties["AccessRead"].Add(true);

第二种是对第一个索引值赋值:

dir.Properties["AccessRead"][0]= true;

这两种方法都是可行的。具体是要看你的喜好了。

在进行赋值之前我们还是要确定要要赋值的目标吧:)这里我们使用DirectoryEntries类的Find方法,如:

DirectoryEntry de = rootfolder.Children.Find("Aspcn","IIsVirtualDir");

找到了,我们就可以赋值了。赋值时一定要好好看看啊,虚拟目录的属性值可以超多,一查一大堆。。:(太多了,飞刀我也不重复了,大家去微软的站点上查:)

比较常用的有:AccessRead,AccessWrite,AccessExecute,AccessScript,DefaultDoc,EnableDefaultDoc,Path

删除虚拟目录

删除虚拟目录的方法也很简单,就是找到你要删除的虚拟目录,然后调用AppDelete方法。

DirectoryEntry de = rootfolder.Children.Find("Aspcn","IIsVirtualDir");

de.Invoke("AppDelete",true);

rootfolder.CommitChanges();

还有一种方法,就是调用Root目录的Delete方法。

object[] paras = new object[2];

paras[0] = "IIsWebVirtualDir"; //表示操作的是虚拟目录

paras[1] = "Aspcn";

rootfolder.Invoke("Delete",paras);

rootfolder.CommitChanges();
 


http://www.niftyadmin.cn/n/1146916.html

相关文章

T-SQL 数据类型

一、精确数字型 1、整数型 数据类型存储长度范围bigint8 字节-9223372036854775808 到 9223372036854775807int4 字节-2147483648 到 2147483648 7smallint2 字节-32768 到 32767tinyint1 字节0,1 或 NULL 2、带国定精度和小数位数的数据类型 数据类型存储长度范围n…

“功夫熊猫”点中大陆动漫产业死穴

在电影中,“功夫熊猫”阿宝使用着从周星驰等功夫巨星那里学来的各种招数打败了邪恶的“残豹”;在电影外,“美国熊猫”的功夫也击中了中国动漫产业的痛处。■ 本报实习记者 梁益畅最近,一只来自好莱坞的“熊猫”突然现身动漫江湖。…

sql server 中游标

我们先不讲游标的什么概念,步骤及语法,先来看一个例子: 表一 OriginSalary 表二 AddSalary现在有2张表,一张是OriginSalary表--工资表,有三个字段0_ID 员工号&…

中国3G蛋糕1.5万亿 10倍三峡工程

◆每经记者 李伟铭 发自成都2008(中国)3G战略高峰论坛7月13日在成都举行,“中国TD之父”、大唐移动通信设备有限公司高级技术顾问李世鹤在论坛上呼吁,与其现在还要花几百上千亿元扩建2G网络,不如拿这笔钱建设3G网络。停止扩建2G,开…

sql server 存储过程、常用系统过程和常用系统函数

SQL Server存储过程Return、output参数及使用技巧SQL Server目前正日益成为WindowNT操作系统上面最为重要的一种数据库管理系统,随着 SQL Server2000的推出,微软的这种数据库服务系统真正地实现了在WindowsNT/2000系列操作系统一统天下的局面&#xff0c…

4亿元期权留给员工 神州数码再辟IT服务新路

神州数码的一场分拆,使董其奇和神州数码IT服务集团的员工们干劲十足。7月3日,神州数码分拆IT服务集团与苏州创投组建的合资公司被正式批准注册。据了解,整个公司引入苏州创投后估值为21.5亿元,而其中有4亿元是预留给员工特别是管理…

sql server 调用存储过程返回值

1.OUPUT参数返回值 CREATE PROCEDURE [dbo].[nb_order_insert]( o_buyerid int , o_id bigint OUTPUT )AS BEGIN SET NOCOUNT ON; BEGIN INSERT INTO [Order](o_buyerid ) VALUES (o_buyerid )SET o_id IDENTITY END END 存储过程中获得方法: DECLARE …

以色列突袭伊朗可能性有多大?

就在关于以色列或美国可能空袭伊朗核设施的猜测沸沸扬扬之时,以色列国防部长巴拉克定于7月14日造访美国。以国防军总参谋长阿什凯纳齐一周后也将赴美。以最高情报机构(摩萨德)负责人梅厄达根此前已经访美。分析人士认为,这一系列访…