ASP.NET 安全认证(一)—— 如何运用 Form 表单认证

转载 2006年06月26日 11:55:00

ASP.NET 安全认证(一)

 

——如何运用 Form 表单认证

 

作者寒羽枫(cityhunter172)

 

 

代码写 N 久了,总想写得别的。这不,上头说在整合两个项目,做成单一登录(Single Sign On),也有人称之为“单点登录”。查阅相关文档后,终于实现了,现在把它拿出来与大家一起分享。或许大家会问:“这与标题不符呀?”别急,在下笔之前,我脑子里想到了我刚使用 Form 认证时遇到的一些问题,以及使用过程用到的一些技巧(实乃投机取巧是也 ^_^ )。偶打初中那时,语文水平就不怎么滴,考试常常作文写不出来,所以写作水平有限,还请大家海量。对了,本人不仅写作水平有限,编程能力也不是很好,此文供大家学习交流之用,欢迎广大劳苦群众拎着鸡蛋、捧着鲜花前来评论。转载请注明原创作者乃寒羽枫是也,不甚感激!

 

废话也说的差不多了,言归正传, ASP.NET 的安全认证,共有“Windows”“Form”“Passport”“None”四种验证模式。“Windows”与“None”没有起到保护的作用,不推荐使用;“Passport”我又没用过,唉……所以我只好讲讲“Form”认证了。我打算分三部分:

 

第一部分 —— 怎样实现From 认证;

 

第二部分 —— Form 认证的实战运用;

 

第三部分 —— 实现单点登录(Single Sign On

 

第一部分 如何运用 Form 表单认证

 

一、        新建一个测试项目

 

为了更好说明,有必要新建一个测试项目(暂且为“FormTest”吧),包含三张页面足矣(Default.aspxLogin.aspxUserInfo.aspx。啥?有人不会新建项目,不会新增页面?你问我咋办?我看这么办好了:拖出去,打回原藉,从幼儿园学起……

 

二、        修改 Web.config

 

1、  双击项目中的Web.config(不会的、找不到的打 PP

 

2、  找到下列文字 <authentication mode="Windows" /> 把它改成:

<authentication mode="Forms">

 

<forms loginUrl="Login.aspx" name=".ASPXAUTH"></forms>

 

</authentication>

 

3、  找到<authorization> <allow users="*" /></authorization>换成

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

 

这里没什么好说的,只要拷贝过去就行。虽说如此,但还是有人会弄错,如下:

 

<authentication mode="Forms">

 

       <forms loginUrl="Login.aspx" name=".APSX"></forms>

 

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

 

 </authentication>

 

若要问是谁把 <deny users="?"></deny> 放入 <authentication> 中的,我会很荣幸地告诉你,那是 N 年前的我:<authentication> <authorization> 都是以 auth 字母开头又都是以 ation 结尾,何其相似;英文单词背不下来的我以为他们是一伙的……

 

三、        编写 .cs 代码——登录与退出

 

1、  登录代码:

 

a、  书本上介绍的

 

         private void Btn_Login_Click(object sender, System.EventArgs e)

 

         {

 

              if(this.Txt_UserName.Text=="Admin" && this.Txt_Password.Text=="123456")

 

              {

 

     System.Web.Security.FormsAuthentication.RedirectFromLoginPage(this.Txt_UserName.Text,false);

 

     }

 

}

 

b、  偶找了 N 久才找到的

 

private void Btn_Login_Click(object sender, System.EventArgs e)

 

         {

 

              if(this.Txt_UserName.Text=="Admin" && this.Txt_Password.Text=="123456")

 

              {

 

System.Web.Security.FormsAuthentication.SetAuthCookie(this.Txt_UserName.Text,false);

 

     Response.Redirect("Default.aspx");

 

     }

 

}

 

以上两种都可发放验证后的 Cookie ,即通过验证,区别:

 

方法 a) 指验证后返回请求页面,俗称“从哪来就打哪去”。比如:用户没登录前直接在 IE 地址栏输入 http://localhost/FormTest/UserInfo.aspx ,那么该用户将看到的是 Login.aspx?ReturnUrl=UserInfo.aspx ,输入用户名与密码登录成功后,系统将根据“ReturnUrl”的值,返回相应的页面

 

方法 b) 则是分两步走:通过验证后就直接发放 Cookie ,跳转页面将由程序员自行指定,此方法多用于 Default.aspx 使用框架结构的系统。

 

 

2、  退出代码:

 

private void Btn_LogOut_Click(object sender, System.EventArgs e)

 

     {

 

System.Web.Security.FormsAuthentication.SignOut();

 

}

 

四、        如何判断验证与否及获取验证后的用户信息

 

有的时候,在同一张页面需要判断用户是否已经登录,然后再呈现不同的布局。有人喜欢用 Session 来判断,我不反对此类做法,在此我只是想告诉大家还有一种方法,且看下面代码:

 

if(User.Identity.IsAuthenticated)

 

         {

 

              //你已通过验证,知道该怎么做了吧?

 

}

 

User.Identity 还有两个属性AuthenticationType(验证类型)与 Name(用户名称) ,大家要注意的是 Name 属性,此处的User.Identity.Name将得到,验证通过(RedirectFromLoginPage SetAuthCookie)时,我们带入的第一个参数 this.Txt_UserName.Text 。这个参数很重要,关系到种种……种种的情况,何出此言,且听下回分解……

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

ASP.NET 安全认证(一)—— 如何运用 Form 表单认证

ASP.NET 安全认证(一) ——如何运用 Form 表单认证 作者:寒羽枫(cityhunter172) 序 代码写 N 久了,总想写得别的。这不,上头说在整合两个项目,做成单一登录(Si...
  • anihasiyou
  • anihasiyou
  • 2014年08月19日 16:42
  • 444

认证模式之Form模式

上面介绍的两种模式都属于HTTP协议规范范畴,由于它的规范使得很多东西无法自定义,例如登录窗口、错误展示页面。所以需要另外一种模式提供更加灵活的认证,也就是基于Form的认证模式。Form模式的认证流...
  • wangyangzhizhou
  • wangyangzhizhou
  • 2016年04月15日 18:13
  • 4906

在Tomcat中采用基于表单的安全验证

1、概述   (1)基于表单的验证   基于From的安全认证可以通过TomcatServer对Form表单中所提供的数据进行验证,基于表单的验证使系统开发者可以自定义用户的登陆页面和报错页面...
  • u011794238
  • u011794238
  • 2015年03月04日 15:55
  • 972

ASP.NET 安全认证(一)—— 如何运用 Form 表单认证 .(转)

第一部分——怎样实现From 认证; 第二部分—— Form 认证的实战运用; 第三部分——实现单点登录(Single Sign On) 第一部分如何运用 Form 表单认证 一、   ...
  • zmoneyz
  • zmoneyz
  • 2014年07月15日 09:21
  • 341

SharePoint 2013 表单认证使用ASP.Net配置工具添加用户

前 言  上面一篇博客,我们了解到如何为SharePoint 2013配置表单身份认证,但是添加用户是一个麻烦事儿;其实,我们还可以用Asp.Net的配置工具,为SharePoint 2013添加表单...
  • linyustar
  • linyustar
  • 2015年07月09日 22:16
  • 1498

SharePoint 2013 配置基于表单的身份认证

前 言  这里简单介绍一下为SharePoint 2013 配置基于表单的身份认证,简单的说,就是用Net提供的工具创建数据库,然后配置SharePoint 管理中心、STS服务、Web应用程序的三处...
  • linyustar
  • linyustar
  • 2015年07月08日 21:52
  • 1630

.NET2.0中Form验证的问题.

最近做一个SSO,使用Form认证方式,结果出了一个很让我郁闷的问题.先描述下问题: 用户登陆时,可以选择是否保存cookie,以便以后直接访问,如果选择否,则在不活动指定时间后,将自动注销. W...
  • albert528108
  • albert528108
  • 2015年04月03日 10:52
  • 489

ASP.NET MVC 表单验证方式总结

一、绑定参数的表单验证:(通过ValidationAttribute特性绑定到Model来验证) 1.引入js文件: jquery的某个版本 jquery.validate.js jquery.val...
  • zhulongxi
  • zhulongxi
  • 2016年05月07日 10:43
  • 4648

asp.net mvc使用表单认证入门

A Beginner's Tutorial on Custom Forms Authentication in ASP.NET MVC Application By Rahul Rajat Sing...
  • imperman
  • imperman
  • 2014年03月24日 19:30
  • 1324

ASP.NET身份验证——Form身份认证

细说ASP.NET Forms身份认证 用户登录是个很常见的业务需求,在ASP.NET中,这个过程被称为身份认证。 由于很常见,因此,我认为把这块内容整理出来,与大家分享应该是件有意义的事。 ...
  • likingsn
  • likingsn
  • 2015年11月03日 11:49
  • 684
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP.NET 安全认证(一)—— 如何运用 Form 表单认证
举报原因:
原因补充:

(最多只允许输入30个字)