2023年11月28日发(作者:)

一、认识文件

文件是一个XML文本文件,它用来储存 ASP.NET Web 应用程序的配置信息(如

最常用的设置ASP.NET Web 应用程序的身份验证方式),它可以出现在应用程序的每一个目

录中。当你通过.NET新建一个Web应用程序后,默认情况下会在根目录自动创建一个默认

文件,包括默认的配置设置,所有的子目录都继承它的配置设置。如果你想

修改子目录的配置设置,你可以在该子目录下新建一个 文件。它可以提供除从

父目录继承的配置信息以外的配置信息,也可以重写或修改父目录中定义的设置。

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

1.配置节处理程序声明

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

2.特定应用程序配置

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

3.配置节设置

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

4.配置节组

特点: 标记,可以自定义分组,可以放到内部或其

标记的内部.

().配置节的每一节

1.

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

2.

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

设置

用法:

I.

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

II.

定义了一个错误 重定向页面.

3.

格式:

defaultLanguage="c#"

debug="true"

/>

t language: 定义后台代码语言,可以选择C#两种语言.

IIdebug : true时,启动aspx调试; false不启动aspx调试,因而可以提高应用程序运

时的性能。 一般程序员在开发时设置为true,交给客户时设置为false.

4.

格式:

mode="RemoteOnly"

defaultRedirect=""

/>

: 具有On,Off,RemoteOnly 3种状态。On表示始终显示自定义的信息; Off表示始终显

示详细的错误信息; RemoteOnly表示只对不在本地Web服务器上运行的用户显示自

定义信息.

tRedirect: 用于出现错误时重定向的URL地址. 是可选的

Code: 指明错误状态码,表明一种特定的出错状态.

IV. redirect:错误重定向的URL.

5.

格式:

requestEncoding="utf-8"

responseEncoding="utf-8"

fileEncoding="utf-8"

/>

tEncoding: 它用来检查每一个发来请求的编码.

seEncoding: 用于检查发回的响应内容编码.

coding: 用于检查aspx,asax等文件解析的默认编码.

6.

格式:

mode="InProc"

stateConnectionString="tcpip=127.0.0.1:42424"

sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"

cookieless="false"

timeout="20"

/>

: 分为off,Inproc,StateServer,SqlServer几种状态

这里有详细介绍此 属性: /chengking/archive/2005/10/27/

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

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

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

V. TimeOut: 用来定义会话状态存储的时间,超过期限,将自动终止会话.

7.

格式:

s: 使用IIS验证方式

: 使用基于窗体的验证方式

rt: 采用Passport cookie验证模式

: 不采用任何验证方式

里面内嵌Forms节点的属性涵义:

: 指定完成身份验证的Http cookie的名称.

rl: 如果未通过验证或超时后重定向的页面URL,一般为登录页面,让用户重新登录

tion: 指定 cookie数据的保护方式.

可设置为: All None Encryption Validation四种保护方式

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

b. None表示不保护Cookie.

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

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

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

在运行时对文件的修改不需要重启服务就可以生 (注: 节例

外)。当然文件是可以扩展的。你可以自定义新配置参数并编写配置节处理程序

以对它们进行处理。

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

<>

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

1

用:配置 ASP.NET 身份验证支持(为WindowsFormsPassPortNone四种)。该元素

只能在计算机、站点或应用程序级别声明。< authentication> 元素必需与

配合使用。

示例:

下示例为基于窗体Forms的身份验证配置站点,当没有登陆的用户访问需要身份验证

的网页,网页自动跳转到登陆网页。

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

2

作用:控制对 URL 资源的客户端访问(如允许匿名用户访问)此元素可以在任何级别(计

算机、站点、应用程序、子目录或页)上声明。必需 节配合使用。

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

使 使

ctFromLoginPage方法将已验证的用户重定向到用户

刚才请 求的页面.具体的

3

作用:配置 ASP.NET 使用的所有编译设置。默认的debug属性为“True”.在程序编译完成交

付使用之后应将其设为False文件中有详细说明,此 处省略示例)

4

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

中发生的错误。

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

其中元素defaultRedirect表示自 定义的错误网页的名称。mode元素表示:对不在本地 Web

服务器上运行的用户显示自定义(友好的)信息。

5

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

声明。

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

maxRequestLength="4096" executionTimeout="60"

appRequestQueueLimit="100"/>

6

作用:标识特定于页的配置 设置(如是否启用会话状态、视图状态,是否检测用户的输入

等)可以在计算机、站点、应用程序和子目录级别声明。

示例:不检测用户在浏览器输入的内容中是否存在潜在的危险数据(注:该项默认是检测,

如果你使用了不检测,一要对用户的输入进行编码或 验证)在从客户端回发页时将检查加

密的视图状态,以验证视图状态是否已在客户端被篡改。(注:该项默认是不验证)

7

作用:为当前应用程序配置会话状态设置(如设置是否启用会话状态,会话状态保存位置)

示例:

注:

mode="InProc"表示:在本地储存会话状态(你也可以选择储存在远程服务器或SAL服务器

中或不启用会话状态)

cookieless="true" 表示:如果用户浏览器不支持Cookie时启用会话状态(默认为False

timeout="20"表示:会话可以处于空闲状态的分钟数

8

作用:配置 ASP.NET 跟踪服务,主要用来程序测试判断哪里出错。

示例:以下为 中的默认配置:

enabled="false" requestLimit="10" pageOutput="false" traceMode="SortByTime"

localOnly="true" />

注:

enabled="false" 表示不启用跟踪;

requestLimit="10"表示指定在服务器上存储的跟踪请求的数目

pageOutput="false"表示 只能通过跟踪实用工具访问跟踪输出;

traceMode="SortByTime"表示以处理跟踪的顺序来显示跟踪信息

localOnly="true" 表示跟踪查看器 () 只用于宿主 Web 服务器

自定义文件配置

自定义文件配置节过程分为两步。

1.在在配置文件顶部 标记之间声明配置节的名称和处

理该节中配置数据的 .NET Framework 类的名称。

2. 是在 区域之后为声明的节做实际的配置设置。

示例:创建一个节存储数 据库连接字符串

name="appSettings" type="lueFileSectionHandler,

System, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>

<>

......

访问文件 你可以通过使用tings 静态字符串集合来

访问 文件示例:获取上面例子中建立的连接字符串。例如:

protected static string Isdebug = tings["debug"]

二、 中的session配置详解

打开某个应用程序的配置文件后,我们会发现以下这段:

< sessionState

mode="InProc"

stateConnectionString="tcpip=127.0.0.1:42424"

sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"

cookieless="false"

timeout="20"

/>

这一段就是配置应用程序是如何存储 Session信息的了。我们以下的各种操作主要是针

对这一段配置展开。让我们先看看这一段配置中所包含的内容的意思。sessionState节点的

法是这样的:

< sessionState mode="Off|InProc|StateServer|SQLServer"

cookieless="true|false"

timeout="number of minutes"

stateConnectionString="tcpip=server:port"

sqlConnectionString="sql connection string"

stateNetworkTimeout="number of seconds"

/>

必须有的属性是 属性 选项 描述

mode 设置将Session信息存储到哪里

Ø Off 设置为不使用Session功能,

Ø InProc 设置为将Session存储在进程内,就是ASP中的存储方式,这是默认值,

Ø StateServer 设置为将Session存储在独立的状态服务中,

Ø SQLServer 设置将Session存储在SQL Server中。

可选的属性是: 属性 选项 描述

Ø cookieless 设置客户端的Session信息存储到哪里,

Ø ture 使用Cookieless模式,

Ø false 使用Cookie模式,这是默认值,

Ø timeout 设置经过多少分钟后服务器自动放弃Session信息,默认为20分钟。

stateConnectionString 设置将Session信息存储在状态服务中时使用的服务器名称和端口号,

例如:"tcpip=127.0.0.1:42424”。当mode的值是 StateServer是,这个属性是必需的。

sqlConnectionString SQL Server"data source=

localhost;Integrated Security=SSPI;Initial Catalog=northwind"。当mode的值是 SQLServer时,

这个属性是必需的。

stateNetworkTimeout 设置当使用StateServer模式存储Session状态时,经过多少秒空闲后,

断开Web服务器与存储状态信息的服务器的TCP/IP连接的。默认 值是10秒钟。

ASP.NET中客户端Session状态的存储

在我们上面的 Session模型简介中,大家可以发现Session状态应该存储在两个地方,

分别是客户端和服务器端。客户端只负责保存相应网站的 SessionID而其他的Session信息

则保存在服务器端。在ASP中,客户端的SessionID实际是以Cookie的形式存储的。如果用

在浏览器的设置中选择了禁用Cookie那末他也就无法享受Session的便利之处了,甚至

造成不能访问某些网站。为了解决以上问题,在 ASP.NET中客户端的Session信息存储方式

分为:CookieCookieless两种。

ASP.NET中,默认状态下,在客户 端还是使用Cookie存储Session信息的。如果我们想

在客户端使用Cookieless的方式存储Session信息的方法如下:

到当前Web应用程序的根目录,打开文件,找到如下段落:

< sessionState

mode="InProc"

stateConnectionString="tcpip=127.0.0.1:42424"

sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"

cookieless="false"

timeout="20"

/>

这段话中的 cookieless="false"改为:cookieless="true",这样,客户端的Session信息就

不再使用 Cookie存储了,而是将其通过URL存储。关闭当前的IE,打开一个新IE,重新访

问刚才的Web应用程序,就会看到类似下面的样子:

其中,localhost/MyTestApplication/(ulqsek45heu3ic2a5zgdl245) /中黑体标出

的就是客户端的Session ID注意,这段信息是由IIS自动加上的,不会影响以前正常的连接。

ASP.NET中服务器端Session状态的存储 准备工作:

为了您能更好的体验到实验现象,您可以建立一个叫做 的页面,然后

把以下这些代码添加到< body>< /body>中。

< scriptrunat="server">

Sub Session_Add(sender As Object, e As EventArgs)

Session("MySession") =

tml = "Session data updated! < P>Your session contains: < font color=red>" &

Session("MySession"). ToString() & "< /font>"

End Sub

Sub CheckSession(sender As Object, eAs EventArgs)

If (Session("MySession")Is Nothing) Then

tml = "NOTHING, SESSION DATA LOST!"

Else

tml = "Your session contains: < font color= red>" &

Session("MySession").ToString() & "< /font>"

End If

End Sub

< /script>

< formrunat="server"id="Form2">

< inputid="text1"type="text"runat="server"name="text1">

< inputtype="submit"runat="server"OnServerClick="Session_Add"

value="Add to Session State " id="Submit1"name="Submit1">

< inputtype="submit"runat="server"OnServerClick="CheckSession"

value=" View Session State " id="Submit2"name="Submit2">

< /form>

< hrsize="1">

< fontsize="6">< spanid="span1"runat="server" />< /font>

这个 的页面可以用来测试在当前的服务器上是否丢失了Session信息。

服务器Session信息存储在进程中

让我们来回到文件的刚才那段段落中:

< 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的值是InProc时,说明服务 器正在使用这种模式。

这种方式和以前ASP中的模式一样,就是服务器将Session信息存储在IIS进程中。IIS

关闭、重起后,这些信 息都会丢失。但是这种模式也有自己最大好处,就是性能最高。应

为所有的Session信息都存储在了IIS的进程中,所以IIS能够很快的访问到这些信 息,这种

模式的性能比进程外存储Session信息或是在SQL Server中存储Session信息都要快上很多。

这种模式也是ASP.NET的默认方式。

好了,现在让我们做个试验。打开刚才的 页面,随便输入一些字符,

使其存储在Session中。然后,让我们让IIS重起。注意,并不是使当前的站点停止再开 始,

而是在IIS中本机的机器名的节点上点击鼠标右键,选择重新启动IIS(想当初使用NT4时,

重新启动IIS必须要重新启动计算机才行,微软真是 @#$%^&)返回到页面

中,检查刚才的Session信息,发现信息已经丢失了。

服务器Session信息存储在进程外

首先,让我们来打开管理工具->服务,找到名为:ASP.NET State Service的服务,启动它。

实际上,这个服务就是启动一个要保存Session信息的进程。启动这个服务后,你可以从

Windows任务管理器 ->进程中看到一个名为 aspnet_的进程,这个就是我们保存

Session信息的进程。

然后,回到 文件中上述的段落中,将mode的值改为StateServer。保存文

件后的重新打开一个IE,打开 页面,保存一些信息到Session中。这时,

让我们重起IIS,再回到页面中查 看刚才的Session信息,发现没有丢失。

实际上,这种将Session信息存储在进程外的方式不光指可以将信息存储在本机的进程

外,还可 以将Session信息存储在其他的服务器的进程中。这时,不光需要将mode的值改

StateServer,还需要在 stateConnectionString中配置相应的参数。例如你的计算你是

192.168.0.1,你想把Session存储在IP 192.168.0.2的计算机的进程中,就需要设置成这

样: stateConnectionString="tcpip=192.168.0.2:42424"。当然,不要忘记在192.168.0.2的计

算机中 装上.NET Framework,并且启动ASP.NET State Services服务。

将服务器 Session信息存储在SQL Server

首先,还是让我们来做一些准备工作。启动SQL ServerSQL Server代理服务。在SQL

Server中执行一个叫做 的脚本文件。这个脚本文件将在SQL Server中创建

一个用来专门存储Session信息的数据库,及一个维护Session信息数据库的SQL Server代理

作业。我们可以在以下路径中找到那个文件:

[system drive]mework[version]

然后打开查询分析器,连接到SQL Server服务器,打开刚才的那个文件并且执行。稍等

片刻,数据库及作业就建立好了。这时,你可以打开企业管理器,看到新增了一个叫ASPState

数据库。但是这个数据库中只是些存储过程,没有用户表。实际上Session信息是存储在

tempdb 数据库的ASPStateTempSessions表中的,另外一个ASPStateTempApplications表存

储了ASP Application对象信息。这两个表也是刚才的那个脚本建立的。另外查看管理->SQL

Server代理->作业,发现也多了一个叫做ASPState_Job_DeleteExpiredSessions的作业,这个

作业实际上就是 每分钟去ASPStateTempSessions 表中删除过期的Session信息的。

接着,我们返回到文件,修改 mode的值改为SQLServer。注意,还要同时

修改sqlConnectionString的值,格式为:

sqlConnectionString="data source=localhost; Integrated Security=SSPI;"

其中data source是指SQL Server服务器的IP地址,如果SQL ServerIIS是一台机子,

127.0.0.1 就行了。Integrated Security=SSPI的意思是使用Windows集成身份验证,这样,

访问数据库将以ASP.NET的身份进行,通过如此配置,能够获得比使用 userid=sa;password=

口令的SQL Server验证方式更好的安全性。当然,如果SQL Server运行于另一台计算机上,

你可能会需要通过Active Directory域的方式来维护两边验证的一致性。

同样,让我们做个试 验。向中添加Session信息,这时发现Session

信息已经存在 SQL Server中了,即使你重起计算机,刚才的Session信息也不会丢失。现在,

你已经完全看见了Session信息到底是什么样子的了,而且又是存储 SQL Server中的,

干什么就看你的发挥了。

总结

通过这篇文章,你可以看到在Session的管理和维护 上,ASP.NETASP有了很大的进

步,我们可以更加随意的挑选适合的方法了。对于企业级的应用来说,这无疑对于服务器的

同步、服务器的稳定性、可靠 性都是有利的。相信在强大的微软支持下,新一代的电子商

务平台将会搭建的更好!

同时,大家也会发现,在这个整个技术中包括了操作 系统、Web服务及数据库多种技

术的整合。我相信,也许Windows没有Unix稳定, IIS没有Apache稳定,SQL Server也没

Oracle强大,但是,谁可以将他们如此完美的联动到一起呢?所以说,虽然微软每一方

面都不是太强,但是如果把微软的东西都整合到一 起,谁敢说他不强大呢?微软就是微软!

三、 关于form认证的一般设置

关于form认证的一般设置:

1: 中,加入form认证;

2: 如果有注册页面时还应该允许匿名用户调用注册页面进行注册;

<>,

<>..之间;

----------------表示允许 匿名用户对 页面进行访问.

<>

3 在登录成功后要创建身份验证票, 表明已经通过认证的合法用户;

if(登陆成功)

hCookie( 户名称, false);

四、访问文件

你可以通过使用 tings 静态字符串集合来访问

文件示例:获取上面例子中建立的连接字符串。例如:

protected static string Isdebug = tings["scon"]