web.config文件中包括一些基本的节,这些节的详细配置如下: 1.配置<authentication> <authentication>节主要用于配置ASP.Net 2.0身份验证.在这一节中,主要对mode属性进行设置,该属性的可选参数有4个,分别为 Windows,Forms,PassPort和None. (1)Windows: Internet信息服务(IIS)根据应用程序的设置执行身份验证.在IIS中必须禁止匿名访问. (2)Forms: 需要工程创建者为用户提供一个输入凭据的自定义窗体,然后在应用程序中验证身份.用户的凭据标记存储于Cookie对象中. (3)PassPort: 身份验证是通过Microsoft的集中身份验证服务执行的,它为成员站点提供了不同用户访问此应用程序的资源. (4)None: 不执行身份验证. 该元素只能在计算机,站点或应用程序级声明.<authentication>节必须与<authorization>节配合使用. eg: 下面代码为<authentication>节基于窗体(Forms)的身份验证配置站点,当没有登录的用户访问需要身份验证的网页时,网页自动跳转倒登录网页,程序代码如下: <authentication mode="Forms"> <forms loginUrl="logon.aspx" name=".FormsAuthCookie"/> </authentication> 2.配置<authorization> <authorization>节用于控制对URL资源的客户端访问权限(如允许匿名用户访问).该元素可以在任何级别(计算机,站点,应用程序,子目录或页)上声明,必须与<authentication>节配合使用. eg: 通过配置<deny users="?"/>禁止匿名用户的访问,程序代码如下: <authorization> <deny users="?"> </authorization> 用户可以使用 user.identity.name 属性来获取已经通过验证的当前用户名,也可以使用Web.Security.FormsAuthentication.RedirectFormLoginPage 方法将已验证的用户重定向到用户请求的页面. 3.配置<compilation> <compilation>节用于配置应用程序的所有编译设置.<compilation>节主要设置两个属性,分别为DefaultLanguage和Debug. (1)DefaultLanguage: 定义了ASP.Net2.0后台代码语言,可以设置成C#,VB等语言. (2)Debug: 该属性设置为True时,将启动aspx调试;设置为False时,可以提高应用程序的运行性能.建议在程序开发调试时,启用该调试;交于客户使用时,关闭调试. 4.配置<customErrors> <customErrors>节用于为ASP.Net应用程序提供有关自定义错误信息的信息.它不适用于XML Web Services中发生的错误. <customErrors>节中主要设置mode属性,此属性有3个可选值. (1)On: 一直显示自定义信息. (2)Off: 一直显示详细的ASP.Net2.0错误信息. (3)RemoteOnly: 只对不在本地Web服务器上运行的用户显示自定义信息. eg. 通过配置<customErrors>节实现发生错误时,将网页跳转到自定义的错误页面. <customErrors defaultRedirect="ErrorPage.aspx" mode="RemoteOnly"> </customErrors> 5.配置<httpRuntime> <httpRuntime>节用于配置ASP.Net2.0运行库设置.该节可以在计算机,站点,应用程序和子目录级别声明. eg. 通过配置<httpRuntime>,指定了用户上传文件最大为4M,最长时间为60s,最多请求数为100. <httpRuntime maxRequestLength="4096" executionTimeout="60" appRequestQueueLimit="100"/>
6.配置<pages> <pages>节用于标识特定页的配置设置(例如,是否启用会话状态或视图状态,是否检测用户的输入等). <pages>页可以在计算机,站点,应用程序和子目录级别声明. eg. 通过配置<pages>节实现不检测用户在浏览器输入的内容中,是否存在潜在的危险数据,在从客户端回发页时将检查加密的视图状态,以及验证视图状态是否已在客户端被篡改. <pages buffer="true" enableViewStateMac="true" validateRequest="false"/> 7.配置<SessionState> <SessionState>节主要用于为当前应用程序配置会话状态设置(例如,设置是否启用会话状态,会话状态保存位置等). <SessionState>各参数的含义如下. (1)mode: 该参数用于设置存储会话状态.会话包括Off,Inproc,StateServer和SqlServer. Off表示禁用回话状态,Inproc表示工作进程自身存储会话状态, StateServer表示将会话信息存放在一个单独的ASP.Net2.0状态服务中,SqlServer表示将会话信息存放在SQL Server数据库中. (2)StateConnectionString: 该参数用于配置ASP.Net2.0应用程序存储远程会话状态的服务器名,默认名为本地. (3)Cookieless: 当参数Cookieless的属性设置为Ture时,表示不使用Cookie会话标识客户;反之设置为False时,表示启动Cookie会话状态. (4)SqlConnectionString: 该参数用于设置SQL Server数据库链接字符. (5)Timeout: 该参数用于设置会话时间,超过该时限,会自动中断会话,默认设置为20分钟. eg. <SessionState mode="InProc" cookieless="true" timeout="20"/> </SessionState> 8.配置<trace> <trace>节用于配置ASP.Net2.0跟踪服务.主要用来判断程序出错的位置. eg. 下面代码为Web.Config中的默认设置: <trace enabled="false" requestLimit="10" pageOutput="false" traceMode="SortByTime" localOnly="true" /> 9.自定义Web.Config文件配置 自定义Web.Config文件配置节过程分为两步,步骤如下. (1)在配置文件顶部<configSections>和</configSection>标记之间,声明配置节的名称和处理该节中配置数据的.NET Framework类名称. (2)在<configSection>区域之后,为已声明的节做实际的配置设置. eg. 下面代码演示了如何创建一个节存储数据库连接字符串: <configuration> <configSections> <section name="appSettings" type="System.Configuration.NameValueFileSectionHandle,System,Version=1.0.3300.0,Culture=neutral, PublickeyToken=b77a5c561934e089"/> </configSections> <appSettings> <add key="sqlcon" value="server=a;database=northwind;uid=sa;pwd=123" /> </appSettings> <system.web> ..... </system.web> </configuration> |
转载于:https://www.cnblogs.com/jackliy/archive/2009/02/10/1387616.html