
web.config
Web.config档案是一个XML文本档案,它用来储存ASP.NETWeb 应用程式的配置信息(如最常用的设定ASP.NETWeb 应用程式的身份验证方式),它可以出现在应用程式的每一个目录中。当你通过.NET新建一个Web应用程式后,默认情况下会在根目录自动创建一个默认的Web.config档案,包括默认的配置设定,所有的子目录都继承它的配置设定。如果你想修改子目录的配置设定,你可以在该子目录下新建一个Web.config档案。它可以提供除从父目录继承的配置信息以外的配置信息,也可以重写或修改父目录中定义的设定。
在运行时对Web.config档案的修改不需要重启服务就可以生效(注: 节例外)。另外Web.config档案也是可以扩展的。你可以自定义新配置参数并编写配置节处理程式以对它们进行处理。
基本介绍
- 中文名:Web配置文
- 外文名:web.config
- 本质:是一个XML文本档案
- 作用:用来储存ASP.NETWeb 的配置信息
- 出现:在应用程式的每一个目录中
- 优点:修改不需要重启服务就可以生效
配置
Web配置档案(*.config)
配置档案
(默认的配置设定)以下所有的代码都应该位于 <configuration> 和 </configuration>
之间,为了学习的方便和直观,下面的示例都省略了这段XML标记
1、<authentication> 节
作用:配置ASP.NET身份验证支持(为Windows、Forms、PassPort、None四种)。该元素只能在计算机、站点或应用程式级别声明。 元素必需与 节配合使用。
示例:
以下示例为基于窗体(Forms)的身份验证配置站点,当没有登入的用户访问需要身份验证的网页,网页自动跳转到登入网页。
其中元素loginUrl表示登入网页的名称,name表示Cookie名称
2、 <authorization>节
作用:控制对 URL 资源的客户端访问(如允许匿名用户访问)。该节可以在任何级别(计算机、站点、应用程式、子目录或页)上声明。必需与 节配合使用。
示例:以下示例禁止匿名用户的访问
注:你可以使用user.identity.name来获取已经过验证的当前的用户名;可以使用
web.Security.FormsAuthentication.RedirectFromLoginPage方法将已验证的用户重定向到用户刚才请求的页面.
3、<compilation>节
作用:配置ASP.NET使用的所有编译设定。默认的debug属性为“True”.在程式编译完成交付使用之后应将其设为"False"(Web.config档案中有详细说明,此处省略示例)
4、<customErrors> 节
作用:为ASP.NET应用程式提供有关自定义错误信息的信息。它不适用于 XML Web services 中发生的错误。
示例:当发生错误时,将网页跳转到自定义的错误页面。
其中元素defaultRedirect表示自定义的错误网页的名称。mode元素表示:对不在本地 Web 伺服器上运行的用户显示自定义信息。
5、<httpRuntime>节
作用:配置 <cite class="highlight" highlight="true">ASP.NET</cite> HTTP 运行库设定。该节可以在计算机、站点、应用程式和子目录级别声明。
示例:控制用户上传档案最大为4M,最长时间为60秒,最多请求数为100
6、<pages> 节
作用:标识特定于页的配置设定(如是否启用会话状态、视图状态,是否检测用户的输入等)。该节可以在计算机、站点、应用程式和子目录级别声明。
示例:不检测用户在浏览器输入的内容中是否存在潜在的危险数据(注:该项默认是检测,如果你使用了不检测,一要对用户的输入进行编码或验证),在从客户端回发页时将检查加密的视图状态,以验证视图状态是否已在客户端被篡改。(注:该项默认是不验证)
7、<sessionState> 节
作用:为当前应用程式配置会话状态设定(如设定是否启用会话状态,会话状态保存位置)。
示例:
注:
mode="InProc"表示:在本地储存会话状态(你也可以选择储存在远程伺服器或SAL伺服器中或不启用会话状态)
cookieless="true"表示:如果用户浏览器不支持Cookie时启用会话状态(默认为False)
timeout="20"表示:会话可以处于空闲状态的分钟数
8、<trace>节
作用:配置ASP.NET跟蹤服务,主要用来程式测试判断哪里出错。
示例:以下为Web.config中的默认配置:
注:
enabled="false"表示不启用跟蹤;requestLimit="10"表示指定在伺服器上存储的跟蹤请求的数目
pageOutput="false"表示只能通过跟蹤实用工具访问跟蹤输出;
traceMode="SortByTime"表示以处理跟蹤的顺序来显示跟蹤信息
localOnly="true" 表示跟蹤查看器 (trace.axd) 只用于宿主 Web 伺服器
自定义
自定义WeB.CONFIG档案配置
自定义Web.config档案配置节过程分为两步。
一是在在配置档案顶部 和 标记之间声明配置节的名称和处理该节中配置数据的 .NET Framework 类的名称。
二是在 区域之后为声明的节做实际的配置设定。
示例:创建一个节存储资料库连线字元串
<configuration>
<configSections>
<section name="appSettings" type="System.Configuration.NameValueFileSectionHandler, System, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
</configSections>
<appSettings>
<add key="scon" value="server=a;database=northwind;uid=sa;pwd=123"/>
</appSettings>
<system.web>
......
</system.web>
</configuration>
访问
访问WEB.CONFIG档案
你可以通过使用ConfigurationSettings.AppSettings 静态字元串集合来访问 Web.config 档案。
示例:获取上面例子中建立的连线字元串。
vb.net
Dim sconstr As String = System.Configuration.ConfigurationManager.AppSettings("ConnectionString")
c#
string connectionString =System.Configuration.ConfigurationManager.AppSettings["ConnectionString"];
创建
创建WEB.CONFIG档案
1.在“解决方案资源管理器”中,单击“刷新”图示以确认应用程式还没有 Web.config 档案。
如果已使用网站管理工具或某些其他方式来配置应用程式,则可能已自动创建了 Web.config 档案。单击“刷新”更新档案列表。
2.在“解决方案资源管理器”中,右击网站名称,然后单击“添加新项”。
3.在“模板”视窗中,单击“Web 配置档案”。
“名称”文本框中的档案名称应为 Web.config。可以为该档案提供其他名称,不过这是默认名称。.config 档案扩展名可防止ASP.NET下载相应档案。
4.单击“添加”创建该档案,然后将其打开进行编辑。
该档案包含本主题后面“示例”部分中显示的代码,并具有一些初始默认值。应用程式从 %SystemRoot%\Microsoft.NET\Framework\<版本>\CONFIG 目录下的 Machine.config 和 Web.config 档案继承所有配置设定,但在此处看不到这些默认设定。如果要重写继承的默认设定或添加 httpHandlers 元素(ASP.NET设定架构) 等集合元素,则只需创建应用程式级别和目录级别的 Web.config 档案。
若要查看当前应用程式的所有配置设定,可以运行主题如何:以编程方式查看继承的配置设定和本地配置设定中包含的代码。也可以查看 %SystemRoot%\Microsoft.NET\Framework\<版本>\CONFIG 目录下的 Machine.config.comments 或 Web.config.comments 档案(这两个档案也包含有用的注释),但这两个档案将不会包含所有运行时设定,请参见如何:以编程方式查看继承的配置设定和本地配置设定。
5.如果更改了 Web.config 档案,则保存该档案。
保存 Web.config 档案会重新启动应用程式。也可以选择使用单个节元素的 configSource 属性指向某个辅助配置档案,更改辅助配置档案不会导致应用程式重新启动。有关更多信息,请参见节元素所继承的常规属性中的 configSource。
转载请注明出处海之美文 » web.config