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"
/>

   default language: 定义后台代码语言,能够选择C#和VB.net两种语言.
   IIdebug : 为true时,启动aspx调试; 为false不启动aspx调试,于是能够提升应用程序运行时的性能。 通常程序员在开发时设置为true,交给客户时设置为false.
   4.<customErrors>节
   格式:
html

<customErrors 
mode="RemoteOnly" 
defaultRedirect="error.aspx"
<error statusCode="440" redirect="err440page.aspx"/>
<error statusCode="500" redirect="err500Page.aspx"/>
/> 
  •  mode : 具备On,Off,RemoteOnly 3种状态。On表示始终显示自定义的信息; Off表示始终显示详细的asp.net错误信息; RemoteOnly表示只对不在本地Web服务器上运行的用户显示自定义信息.
  • defaultRedirect: 用于出现错误时重定向的URL地址. 是可选的
  • statusCode: 指明错误状态码,代表一种特定的出错状态.
  • redirect:错误重定向的URL.

    5.<globalization>节
格式:
程序员

<globalization 
requestEncoding="utf-8" 
responseEncoding="utf-8" 
fileEncoding="utf-8"
/> 
  • requestEncoding: 它用来检查每个发来请求的编码.
  • responseEncoding: 用于检查发回的响应内容编码.
  • fileEncoding: 用于检查aspx,asax等文件解析的默认编码.


6.<sessionState>节
格式:
sql

<sessionState 
mode="InProc"
stateConnectionString="tcpip=127.0.0.1:42424"
sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"
cookieless="false" 
timeout="20" 
/>
  • mode: 分为off,Inproc,StateServer,SqlServer几种状态这里有详细介绍此属性:  

              Asp.net有三种方式存储会话状态信息:
                  1. 存储在进程中: 属性mode = InProc
                    特色:  具备最佳的性能,速度最快,但不能跨多台服务器存储共享.
 
                2. 存储在状态服务器中: 属性mode = "StateServer"
                     特色:   当须要跨服务器维护用户会话信息时,使用此方法。 可是信息存储在状态服务器上,一旦状态服务器出现故障,信息将丢失
   
               3. 存储在Sql Server中: 属性mode="SqlServer"
                      特色:   工做负载会变大,但信息不会丢失.
   
                 补充一点:
                      I. 因为某些页面不须要会话状态,则能够将会话状态禁用:
                           代码以下: <%@ Page EnableSessionState="false" %>
                      II.若是页面须要访问会话变量但不容许修改它们,能够设置页面会话状态为只读:
                           代码以下: <%@ Page EnableSessionState="false" %>
数据库

  •  stateConnectionString :指定Asp.net应用程序存储远程会话状态的服务器名,默认为本机
  • sqlConnectionString: 当用会话状态数据库时,在这里设置链接字符串
  • Cookieless: 设置为true时,表示不使用cookie会话状态来标识客户; 不然,相反.
  • TimeOut: 用来定义会话状态存储的时间,超过时限,将自动终止会话.


   7.<authentication>节
   格式:
c#

<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的失效时间. 超时后要从新登陆.
服务器

转载于:https://www.cnblogs.com/xtsong/archive/2008/06/05/1214528.htmlcookie