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

转载 2014年07月15日 09:21:01

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

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

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

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

一、        新建一个测试项目

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

二、        修改 Web.config

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

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

<authenticationmode="Forms">

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

</authentication>

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

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

 

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

<authenticationmode="Forms">

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

<denyusers="?"></deny>

 </authentication>

若要问是谁把<denyusers="?"></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将得到,验证通过(RedirectFromLoginPageSetAuthCookie)时,我们带入的第一个参数this.Txt_UserName.Text 。这个参数很重要,关系到种种……种种的情况,何出此言,且听下回分解……

ASP.NET 安全认证(二)——灵活运用 Form 表单认证中的 deny allow 及保护 .htm 等文件

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

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

Asp.Net MVC中身份认证和授权

 http://blog.csdn.net/kenshincui/article/details/5559508 MVC自带的ActionFilter 在Asp.Net WebFor...
  • Lyncai
  • Lyncai
  • 2015年03月16日 21:09
  • 3168

shiro表单登录认证及退出(自定义form认证器)

博主地址:http://blog.csdn.net/zcl_love_wx 注意:此文是基于springMVC框架的,所以关于springMVC的配置这里不说,后面有时间专门写一个shiro整合s...
  • zcl_love_wx
  • zcl_love_wx
  • 2016年06月03日 11:20
  • 1550

【原创】ASP.NET 安全认证(二)——灵活运用 Form 表单认证中的 deny 与 allow 及保护 .htm 等文件 .(转)

第二部分 Form 认证的实战运用  话说上回,简单地说了一下 Form 表单认证的用法。或许大家觉得太简单,对那些大内高手来说应该是“洒洒水啦”“小 Kiss 啦(小意思)”。今天咱们来点的...
  • zmoneyz
  • zmoneyz
  • 2014年07月15日 09:22
  • 407

ASP.NET 安全认证(二)——灵活运用 Form 表单认证中的 deny 与 allow 及保护 .htm 等文件

【原创】ASP.NET 安全认证(二) ——灵活运用 Form 表单认证中的 deny 与 allow 及保护 .htm 等文件 作者:寒羽枫(cityhunter172) 第二部分 Form ...
  • anihasiyou
  • anihasiyou
  • 2014年08月19日 16:46
  • 365

【原创】ASP.NET 安全认证(三)—— 用Form 表单认证实现单点登录(Single Sign On)(转)

第三部分实现单点登录(Single Sign On)  “等了好久终于等到今天,写了好久终于就快完结,但是网友的反应却让我有一些的伤心。盼了好久终于盼到今天,忍了好久终于把此文撰写,那些受冷落的无奈...
  • zmoneyz
  • zmoneyz
  • 2014年07月15日 09:24
  • 1222

ASP.NET 安全认证(四)——巧妙实现 Form 表单认证跨站点、跨服务器的单点登录(Single Sign On)

【原创】ASP.NET 安全认证(四) ——巧妙实现 Form 表单认证跨站点、跨服务器的单点登录(Single Sign On) 作者:寒羽枫(cityhunter172) 第四部分 Fo...
  • gaoxu529
  • gaoxu529
  • 2012年11月25日 21:47
  • 868

ASP.NET 安全认证(三)—— 用Form 表单认证实现单点登录(Single Sign On)

【原创】ASP.NET 安全认证(三) ——用Form 表单认证实现单点登录(Single Sign On) 作者:寒羽枫(cityhunter172) 第三部分 实现单点登录(Single...
  • anihasiyou
  • anihasiyou
  • 2014年08月19日 16:47
  • 827

ASP.NET 安全认证(四)——巧妙实现 Form 表单认证跨站点、跨服务器的单点登录(Single Sign On)

【原创】ASP.NET 安全认证(四) ——巧妙实现 Form 表单认证跨站点、跨服务器的单点登录(Single Sign On) 作者:寒羽枫(cityhunter172) 第四部分 Fo...
  • anihasiyou
  • anihasiyou
  • 2014年08月19日 16:48
  • 884

ASP.NET 安全认证(一):怎么运用 Form 表单认证

使用 Form 认证时遇见的一些问题,及使用过程用到的一些技巧
  • oagnuygnef
  • oagnuygnef
  • 2011年03月02日 08:43
  • 358
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP.NET 安全认证(一)—— 如何运用 Form 表单认证 .(转)
举报原因:
原因补充:

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