webconfig 部分配置

来源:互联网 发布:淘宝永久封号怎么解封 编辑:程序博客网 时间:2024/05/18 10:13

webconfig 部分配置

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>

          <!--为 ASP.NET 应用程序配置页的视图状态设置。设置要存储在页历史记录中的项数。-->
       <sessionPageState historySize="9"/>

 

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>

 

web.config常用

 

(一).Web.Config是以XML文件规范存储,配置文件分为以下格式
    1.配置节处理程序声明
      特点: 位于配置文件的顶部,包含在<configSections>标志中。
    2.特定应用程序配置
      特点: 位于<appSetting>中。 可以定义应用程序的全局常量设置等信息.
    3.配置节设置
      特点: 位于<system.Web>节中,控制Asp.net运行时的行为.
    4.配置节组
      特点: 用<sectionGroup>标记,可以自定义分组,可以放到<configSections>内部或其它<sectionGroup>标记的内部.

(二).配置节的每一节
    1.<configuration>节
        根元素,其它节都是在它的内部.
    2.<appSetting>节
        此节用于定义应用程序设置项。对一些不确定设置,还可以让用户根据自己实际情况自己设置
        用法:
        I.
         <appSettings>
     <add key="Conntction" value="server=192.168.85.66;userid=sa;password=;database=Info;"/>
         <appSettings>
        定义了一个连接字符串常量,并且在实际应用时可以修改连接字符串,不用修改程式代码.
        II.<appSettings>
      <add key="ErrPage" value="Error.aspx"/>
           <appSettings>
        定义了一个错误重定向页面.
     3.<compilation>节
        格式:
          <compilation
             defaultLanguage="c#"
             debug="true"
           />
        I.default language: 定义后台代码语言,可以选择C#和VB.net两种语言.
        IIdebug : 为true时,启动aspx调试; 为false不启动aspx调试,因而可以提高应用程序运行
                  时的性能。 一般程序员在开发时设置为true,交给客户时设置为false.
     4.<customErrors>节
         格式:
         <customErrors
            mode="RemoteOnly"
            defaultRedirect="error.aspx"
            <error statusCode="440" redirect="err440page.aspx"/>
            <error statusCode="500" redirect="err500Page.aspx"/>
         />
         I.mode : 具有On,Off,RemoteOnly 3种状态。On表示始终显示自定义的信息; Off表示始终显示详细的asp.net错误信息; RemoteOnly表示只对不在本地Web服务器上运行的用户显示自定义信息.
         II.defaultRedirect: 用于出现错误时重定向的URL地址. 是可选的
         III.statusCode: 指明错误状态码,表明一种特定的出错状态.
         IV. redirect:错误重定向的URL.
      5.<globalization>节
          格式:
          <globalization
             requestEncoding="utf-8"
             responseEncoding="utf-8"
             fileEncoding="utf-8"
          />
          I.requestEncoding: 它用来检查每一个发来请求的编码.
          II.responseEncoding: 用于检查发回的响应内容编码.
          III.fileEncoding: 用于检查aspx,asax等文件解析的默认编码.   
      6.<sessionState>节
          格式:
          <sessionState
            mode="InProc"
            stateConnectionString="tcpip=127.0.0.1:42424"
            sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"
            cookieless="false"
            timeout="20"
          />
          I.mode: 分为off,Inproc,StateServer,SqlServer几种状态
           II. stateConnectionString :指定Asp.net应用程序存储远程会话状态的服务器名,默认为本机
          III.sqlConnectionString: 当用会话状态数据库时,在这里设置连接字符串
          IV. Cookieless: 设置为true时,表示不使用cookie会话状态来标识客户; 否则,相反.
          V. TimeOut: 用来定义会话状态存储的时间,超过期限,将自动终止会话.
      7.<authentication>节
        格式:
         <authentication mode="Forms">             
             <forms name=".ASPXUSERDEMO" loginUrl="Login.aspx" protection="All" timeout="30"/>
         </authentication>
         <authorization>
             <deny users="?"/>
         </authorization>
         I.Windows: 使用IIS验证方式
         II.Forms: 使用基于窗体的验证方式
         III.Passport: 采用Passport cookie验证模式
         IV.None: 不采用任何验证方式
         里面内嵌Forms节点的属性涵义:
         I.Name: 指定完成身份验证的Http cookie的名称.
         II.LoginUrl: 如果未通过验证或超时后重定向的页面URL,一般为登录页面,让用户重新登录
         III.Protection: 指定 cookie数据的保护方式.
            可设置为: All None Encryption Validation四种保护方式
            a. All表示加密数据,并进行有效性验证两种方式
            b. None表示不保护Cookie.
            c. Encryption表示对Cookie内容进行加密
            d. validation表示对Cookie内容进行有效性验证
         IV. TimeOut: 指定Cookie的失效时间. 超时后要重新登录.
 
ASP.NET的Web.Config 节点的属性设置说明
http://msdn.microsoft.com/zh-cn/library/b5ysx397(VS.80).aspx


<system.web>
<anonymousIdentification>
<authentication>
<authorization>
<browserCaps>
<caching>
<clientTarget>
<compilation>
<customErrors>
<deployment>
<deviceFilters>
<globalization>
<healthMonitoring>
<hostingEnvironment>
<httpCookies>
<httpHandlers>
<httpModules>
<httpRuntime>
<identity>
<machineKey>
<membership>
<mobileControls>
<pages>
<processModel>
<profile>
<roleManager>
<securityPolicy>
<sessionPageState>
<sessionState>
<siteMap>
<trace>
<trust>
<urlMappings>
<webControls>
<webParts>
<webServices>
<xhtmlConformance>

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/yxyx_2005/archive/2010/01/30/5271468.aspx