转载

认识Web.config文件

Web.config 文件是一个XML文本文件,它用来储存 ASP.NET Web 应用程序的配置信息(如最常用的设置ASP.NET Web 应用程序的身份验证方式),它可以出现在应用程序的每一个目录中。当你通过.NET新建一个Web应用程序后,默认情况下会在根目录自动创建一个默认的 Web.config文件,包括默认的配置设置,所有的子目录都继承它的配置设置。如果你想修改子目录的配置设置,你可以在该子目录下新建一个 Web.config文件。它可以提供除从父目录继承的配置信息以外的配置信息,也可以重写或修改父目录中定义的设置。

(一).Web.Config是以XML文件规范存储,配置文件分为以下格式

1.配置节处理程序声明

特点:位于配置文件的顶部,包含在 <configSections> 标志中。

2.特定应用程序配置

特点: 位于 <appSetting> 中。 可以定义应用程序的全局常量设置等信息.

3.配置节设置

特点: 位于 <system.Web> 节中,控制Asp.net运行时的行为.

4.配置节组

特点: 用 <sectionGroup> 标记,可以自定义分组,可以放到 <configSections> 内部或其它 <sectionGroup> 标记的内部.

(二).配置节的每一节

1. <configuration>

根元素,其它节都是在它的内部.

2. <appSetting>

此节用于定义应用程序设置项。对一些不确定设置,还可以让用户根据自己实际情况自己设置 用法:

定义了一个连接字符串常量,并且在实际应用时可以修改连接字符串,不用修改程式代码.

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

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几种状态

这里有详细介绍此属性: http://blog.csdn.net/chengking/archive/2005/10/27/518079.aspx

II. stateConnectionString :指定Asp.net应用程序存储远程会话状态的服务器名,默认为本机

III.sqlConnectionString: 当用会话状态数据库时,在这里设置连接字符串

IV. Cookieless: 设置为true时,表示不使用cookie会话状态来标识客户; 否则,相反.

  1. 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四种保护方式

  1. All表示加密数据,并进行有效性验证两种方式

  2. None表示不保护Cookie.

  3. Encryption表示对Cookie内容进行加密

  4. validation表示对Cookie内容进行有效性验证

IV. TimeOut: 指定Cookie的失效时间. 超时后要重新登录.

在运行时对Web.config文件的修改不需要重启服务就可以生效(注: <processModel> 节例外)。当然Web.config文件是可以扩展的。你可以自定义新配置参数并编写配置节处理程序以对它们进行处理。

web.config配置文件(默认的配置设置)以下所有的代码都应该位于

<configuration>  <system.web>  和  </system.web>  </configuration>  

之间,出于学习的目的下面的示例都省略了这段XML标记。

1、 <authentication>

作用:配置 ASP.NET 身份验证支持(为Windows、Forms、PassPort、None四种)。该元素只能在计算机、站点或应用程序级别声明。 <authentication> 元素必需与 <authorization> 节配合使用。

示例:

以下示例为基于窗体(Forms)的身份验证配置站点,当没有登陆的用户访问需要身份验证的网页,网页自动跳转到登陆网页。

<authentication   mode= "Forms "   >  <forms   loginUrl= "logon.aspx "   name= ".FormsAuthCookie "/>  </authentication>  

其中元素loginUrl表示登陆网页的名称,name表示Cookie名称。

2、 <authorization>

作用:控制对 URL 资源的客户端访问(如允许匿名用户访问)。此元素可以在任何级别(计算机、站点、应用程序、子目录或页)上声明。必需与 节配合使用。

示例:以下示例禁止匿名用户的访问

<authorization>        <deny   users= "? "/>  </authorization>  

注:你可以使用user.identity.name来获取已经过验证的当前的用户名;可以使用web.Security.FormsAuthentication.RedirectFromLoginPage方法将已验证的用户重定向到用户刚才请求的页面.具体的

3、 <compilation>

作用:配置 ASP.NET 使用的所有编译设置。默认的debug属性为“True”.在程序编译完成交付使用之后应将其设为False(Web.config文件中有详细说明,此处省略示例)

4、 <customErrors>

作用:为 ASP.NET 应用程序提供有关自定义错误信息的信息。它不适用于 XML Web services 中发生的错误。

示例:当发生错误时,将网页跳转到自定义的错误页面。

<customErrors   defaultRedirect= "ErrorPage.aspx "   mode= "RemoteOnly ">  </customErrors>  

其中元素defaultRedirect表示自定义的错误网页的名称。mode元素表示:对不在本地 Web 服务器上运行的用户显示自定义(友好的)信息。

5、 <httpRuntime>

作用:配置 ASP.NET HTTP 运行库设置。该节可以在计算机、站点、应用程序和子目录级别声明。

示例:控制用户上传文件最大为4M,最长时间为60秒,最多请求数为100

<httpRuntime   maxRequestLength= "4096 "   executionTimeout= "60 "   appRequestQueueLimit= "100 "/>   ConfigurationSettings.AppSettings[ "scon "] 

实例代码:

<?xml version="1.0" encoding="utf-8"?>  <configuration>   <configSections>   <sectionGroup name="system.web.extensions" type="System.Web.Configuration.SystemWebExtensionsSectionGroup, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">     <sectionGroup name="scripting" type="System.Web.Configuration.ScriptingSectionGroup, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">       <section name="scriptResourceHandler" type="System.Web.Configuration.ScriptingScriptResourceHandlerSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="MachineToApplication"/>       <sectionGroup name="webServices" type="System.Web.Configuration.ScriptingWebServicesSectionGroup, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">         <section name="jsonSerialization" type="System.Web.Configuration.ScriptingJsonSerializationSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="Everywhere" />         <section name="profileService" type="System.Web.Configuration.ScriptingProfileServiceSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="MachineToApplication" />         <section name="authenticationService" type="System.Web.Configuration.ScriptingAuthenticationServiceSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="MachineToApplication" />         <section name="roleService" type="System.Web.Configuration.ScriptingRoleServiceSection, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" requirePermission="false" allowDefinition="MachineToApplication" />       </sectionGroup>     </sectionGroup>   </sectionGroup>   <section name="beitmemcached" type="System.Configuration.NameValueSectionHandler"/> </configSections>  <beitmemcached> <add key="UserCache" value="127.0.0.1:11211"/> </beitmemcached> <appSettings> <!--Memcache缓存时间,单位:分--> <add key="UserCacheTime" value="2"/> <!--官网地址--> <add key="WebSiteUrl" value="http://service.70yx.com"/> <!-- 注册页 --> <add key="RegisterPage" value="http://reg.70yx.com/register.aspx"/> <!-- 登录页 --> <add key="LoginPage" value="http://reg.70yx.com/Login.aspx"/> <!--退出登录页--> <add key="LogoutPage" value="http://reg.70yx.com/logout.aspx"/> <!--提示页--> <add key="MsgPage" value="/msg.aspx"/> <!-- 统计当前时间的前多少天的问题,默认为30--> <add key="ValidateKey" value="wjf)#@^"/> <!--验证码存储方式 c:cookie;s:session,m:memcached--> <add key="ValidateMethod" value="s"/> <!--m--> <add key="Days" value="-50"/> <add key="count" value="8"/> <!-- 受理码默认长度--> <add key="MainIdLengh" value="8"/> <!--登录cookie名--> <add key="LoginCookieName" value="70yxPassportUser,70yxBaiduPassportUser,70yxFunshionPassportUser"/> <!--登录cookie过期时间--> <add key="CookieExpireTime" value="0"/> <!--登录cookie是否写域,1是--> <add key="NeedCookieDomain" value="1"/> <!-- 用户登录密码加密密钥 --> <add key="PwdSecret" value="qck$7@w"/> <!--登录认证的连接串名称,权限、用户、角色表所在的数据库,连接串名称在下面;每个用到登录认证的项目必须加这项!--> <add key="UserRightConnectName" value="151"/> <!--登录私钥--> <add key="LoginSecret" value="Ta@x$^s)L"/> <add key="DbProvider" value="Qlyx.Broker.SqlDataProvider"/> <!--DB是否使用内网连接--> <add key="DBIntranet" value="true"/> <!--GameDB是否使用内网连接--> <add key="GameDBIntranet" value="true"/> <!--是否连接电话密保DB--> <add key="ConnectPhoneDB" value="false" /> <!--是否连接密保卡DB--> <add key="ConnectSecretCardDB" value="false" /> <!--是否连接随身密保DB--> <add key="ConnectPasspodDB" value="false" /> <!--后台知识库附件存储的物理路径--> <add key="RepositoryAttPath" value="E:/projects/Service.root/Service/Qlyx.Service1.2/FupFiles/"/> </appSettings> <connectionStrings> <add name="jwfConnectionString" connectionString="Data Source=192.168.3.203;Initial Catalog=jwf;User ID=sa;Password=70yxtech20100423;Pooling=true;Connection Reset=true;Connection Lifetime=60;Min Pool Size=;Max Pool Size=100"/>   </connectionStrings>  <system.web>     <!--          设置 compilation debug="true" 可将调试符号插入         已编译的页面中。但由于这会          影响性能,因此只在开发过程中将此值          设置为 true。     -->     <compilation debug="true">        <assemblies>         <add assembly="System.Core, Version=3.5.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089"/>         <add assembly="System.Data.DataSetExtensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089"/>         <add assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>         <add assembly="System.Xml.Linq, Version=3.5.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089"/>       </assemblies>      </compilation>     <!--         通过 <authentication> 节可以配置 ASP.NET 用来          识别进入用户的         安全身份验证模式。      -->     <authentication mode="Windows" />     <!--         如果在执行请求的过程中出现未处理的错误,         则通过 <customErrors> 节可以配置相应的处理步骤。具体说来,         开发人员通过该节可以配置         要显示的 html 错误页         以代替错误堆栈跟踪。      <customErrors mode="RemoteOnly" defaultRedirect="GenericErrorPage.htm">         <error statusCode="403" redirect="NoAccess.htm" />         <error statusCode="404" redirect="FileNotFound.htm" />     </customErrors>     -->   <customErrors mode="Off"/>   <globalization requestEncoding="gb2312" responseEncoding="gb2312"/>   <sessionState mode="InProc" stateConnectionString="tcpip=127.0.0.1:42424" sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes" cookieless="false" timeout="20"/>    <pages>     <controls>       <add tagPrefix="asp" namespace="System.Web.UI" assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>       <add tagPrefix="asp" namespace="System.Web.UI.WebControls" assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>     </controls>   </pages>    <httpHandlers>     <remove verb="*" path="*.asmx"/>     <add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>     <add verb="*" path="*_AppService.axd" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>     <add verb="GET,HEAD" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" validate="false"/>   </httpHandlers>   <httpModules>     <add name="ScriptModule" type="System.Web.Handlers.ScriptModule, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>   </httpModules>  </system.web>  <system.codedom>   <compilers>     <compiler language="c#;cs;csharp" extension=".cs" warningLevel="4"               type="Microsoft.CSharp.CSharpCodeProvider, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">       <providerOption name="CompilerVersion" value="v3.5"/>       <providerOption name="WarnAsError" value="false"/>     </compiler>  </compilers> </system.codedom>  <!--      在 Internet 信息服务 7.0 下运行 ASP.NET AJAX 需要 system.webServer     节。对早期版本的 IIS 来说则不需要此节。 --> <system.webServer>   <validation validateIntegratedModeConfiguration="false"/>   <modules>     <remove name="ScriptModule" />     <add name="ScriptModule" preCondition="managedHandler" type="System.Web.Handlers.ScriptModule, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>   </modules>   <handlers>     <remove name="WebServiceHandlerFactory-Integrated"/>     <remove name="ScriptHandlerFactory" />     <remove name="ScriptHandlerFactoryAppServices" />     <remove name="ScriptResource" />     <add name="ScriptHandlerFactory" verb="*" path="*.asmx" preCondition="integratedMode"          type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>     <add name="ScriptHandlerFactoryAppServices" verb="*" path="*_AppService.axd" preCondition="integratedMode"          type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>     <add name="ScriptResource" preCondition="integratedMode" verb="GET,HEAD" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />   </handlers> </system.webServer>  <runtime>   <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">     <dependentAssembly>       <assemblyIdentity name="System.Web.Extensions" publicKeyToken="31bf3856ad364e35"/>       <bindingRedirect oldVersion="1.0.0.0-1.1.0.0" newVersion="3.5.0.0"/>     </dependentAssembly>     <dependentAssembly>       <assemblyIdentity name="System.Web.Extensions.Design" publicKeyToken="31bf3856ad364e35"/>       <bindingRedirect oldVersion="1.0.0.0-1.1.0.0" newVersion="3.5.0.0"/>     </dependentAssembly>   </assemblyBinding> </runtime>  </configuration> 

1.ConfigurationManager提供对客户端应用程序配置文件的访问。

其有两个属性1.ConnectionStrings 获取当前应用程序默认配置的 ConnectionStringsSection 数据。

方法一:

string myConn =System.Configuration.ConfigurationManager.ConnectionStrings["sqlConnectionString"].ConnectionString; 

方法二:

string connString =System.Web.Configuration.WebConfigurationManager.ConnectionStrings["sqlConnectionString"].ToString(); 

web.config中的配置为:

<configuration> <connectionStrings>     <add name="sqlConnectionString" connectionString="LocalSqlServer: data source=127.0.0.1;Integrated Security=SSPI;Initial Catalog=aspnetdb"       providerName="System.Data.SqlClient" /> </connectionStrings> </configuration> 

2.AppSettings 获取当前应用程序默认配置的 AppSettingsSection 数据。

string myConn = ConfigurationManager.AppSettings["sqlConnectionString"].ToString(); web.config中的配置为: <configuration> <appSettings>     <add key="sqlConnectionString" value="Monday, January 23, 2006 2:56:14 PM" /> </appSettings> </configuration> 

Resource Reference

原文  http://cnbin.github.io/blog/2016/01/23/ren-shi-web-dot-configwen-jian/
正文到此结束
Loading...