ASP.NET 2.0 中的窗体身份验证

作者:佚名 文章来源:不详 点击数: 更新时间:2008-2-15 13:49:34
概述

  窗体身份验证使用用户登录到站点时创建的身份验证票,然后在整个站点内跟踪该用户。窗体身份验证票通常包含在一个 Cookie 中。然而,ASP.NET 2.0 版支持无 Cookie 窗体身份验证,结果是将票证传入查询字符串中。

  如果用户请求一个需要经过身份验证的访问的页,且该用户以前没有登录过该站点,则该用户重定向到一个配置好的登录页。该登录页提示用户提供凭据(通常是用户名和密码)。然后,将这些凭据传递给服务器并针对用户存储(如 SQL Server 数据库)进行验证。在 ASP.NET 2.0 中,用户存储访问可由成员身份提供程序处理。对用户的凭据进行身份验证后,用户重定向到原来请求的页面。

  窗体身份验证处理由 FormsAuthenticationModule 类实现,该类是一个参与常规 ASP.NET 页处理循环的 HTTP 模块。本文阐释 ASP.NET 2.0 中窗体身份验证的工作机制。


  IIS 身份验证

  ASP.NET 身份验证分为两个步骤。首先,Internet 信息服务 (IIS) 对用户进行身份验证,并创建一个 Windows 令牌来表示该用户。IIS 通过查看 IIS 元数据库设置,确定应该对特定应用程序使用的身份验证模式。如果 IIS 配置为使用匿名身份验证,则为 IUSR_MACHINE 帐户生成一个令牌并用它表示匿名用户。然后,IIS 将该令牌传递给 ASP.NET。

  其次,ASP.NET 执行自己的身份验证。所使用的身份验证方法由 authentication 元素的 mode 属性指定。以下身份验证配置指定 ASP.NET 使用 FormsAuthenticationModule 类:

<authentication mode="Forms" />

   由于窗体身份验证不依赖于 IIS 身份验证,因此如果要在 ASP.NET 应用程序中使用窗体身份验证,则应该在 IIS 中为应用程序配置匿名访问。

  ASP.NET 窗体身份验证

  ASP.NET 窗体身份验证在 IIS 身份验证完成后发生。可以使用 forms 元素配置窗体身份验证。

  窗体身份验证配置

  以下配置文件片段显示窗体身份验证的默认属性值。

<system.web> 

  <authentication mode="Forms"> 

    <forms loginUrl="Login.aspx" 

           protection="All" 

           timeout="30" 

           name=".ASPXAUTH"  

           path="/" 

           requireSSL="false" 

           slidingExpiration="true" 

           defaultUrl="default.aspx" 

           cookieless="UseDeviceProfile" 

           enableCrossAppRedirects="false" /> 

  </authentication> 

</system.web> 

  下面是对默认属性值的描述:

·
loginUrl 指向应用程序的自定义登录页。应该将登录页放在需要安全套接字层 (SSL) 的文件夹中。这有助于确保凭据从浏览器传到 Web 服务器时的完整性。
·
protection 设置为 All,以指定窗体身份验证票的保密性和完整性。这导致使用 machineKey 元素上指定的算法对身份验证票证进行加密,并且使用同样是 machineKey 元素上指定的哈希算法进行签名。
·
timeout 用于指定窗体身份验证会话的有限生存期。默认值为 30 分钟。如果颁发持久的窗体身份验证 Cookie,timeout 属性还用于设置持久 Cookie 的生存期。
·
namepath 设置为应用程序的配置文件中定义的值。
·
requireSSL 设置为 false。该配置意味着身份验证 Cookie 可通过未经 SSL 加密的信道进行传输。如果担心会话窃取,应考虑将 requireSSL 设置为 true
·
slidingExpiration 设置为 true 以执行变化的会话生存期。这意味着只要用户在站点上处于活动状态,会话超时就会定期重置。
·
defaultUrl 设置为应用程序的 Default.aspx 页。
·
cookieless 设置为 UseDeviceProfile,以指定应用程序对所有支持 Cookie 的浏览器都使用 Cookie。如果不支持 Cookie 的浏览器访问该站点,窗体身份验证在 URL 上打包身份验证票。
·
enableCrossAppRedirects 设置为 false,以指明窗体身份验证不支持自动处理在应用程序之间传递的查询字符串上的票证以及作为某个窗体 POST 的一部分传递的票证。

[1] [2] [3] [4] [5] 下一页

关于 ASP.NET 2.0 中的窗体身份验证 的
  • 文章

【字体:小 大】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
讨论区
  网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

E时代学生网FLASH推荐

分类信息
E时代学生网,电脑教程!
时代学生网 Copyright© WWW.E-STU.NET All Right Reserved.
让"E时代学生网" 陪你一起走过美好的学生时代吧!
网站:教育新闻,历年试题,考试新闻,校园故事,校园生活,教师资源,学生资源,教学课件,教学软件,电子图书,教学工具,教材教案,教育论文,教育视频,儿童动画,教学案例,儿童英语,英语学习,同步学习,教育影片,电影娱乐,在线电视,试题练习,视频课堂
客服QQ: 28733986 325515581 备案序号:鲁ICP备06039656号 网页浏览最佳分辨率:1024*768
学生家长,老师QQ群:①41360566 ②23572281 ③23505589 ④33658545 大学生QQ群:①31892528