Form表单实现ASP.NET认证

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

  第一部分 —— 怎样实现Form表单认证;

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

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

  第一部分 如何运用Form表单进行ASP.NET认证

  一、新建一个测试项目

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

  二、修改Web.config

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

  2、找到下列文字 把它改成:

<authentication mode="Forms"> 
<forms loginUrl="Login.aspx" name=".ASPXAUTH">forms> 
authentication> 

  3、找到 换成

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

  {  

  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、ASP.NET认证退出代码:

private void Btn_LogOut_Click(object sender, System.EventArgs e)  
     {  
System.Web.Security.FormsAuthentication.SignOut();  
} 

  四、如何判断ASP.NET认证与否及获取ASP.NET认证 后的用户信息

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

if(User.Identity.IsAuthenticated)  
         {  
              //你已通过ASP.NET认证,知道该怎么做了吧?  
} 

  User.Identity 还有两个属性AuthenticationType(验证类型)与 Name(用户名称) ,大家要注意的是Name属性,此处的User.Identity.Name将得到,验证通过(RedirectFromLoginPage 或SetAuthCookie)时,我们带入的第一个参数 this.Txt_UserName.Text 。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值