首页 > 编程 > .NET > 正文

ASP.NET 安全认证(一)

2024-07-10 13:06:14
字体:
来源:转载
供稿:网友

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

 

 

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

 

 

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

 

 

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

 

 

第三部分 —— 实现单点登录(single sign on)

 

 

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

 

 

一、        新建一个测试项目

 

 

为了更好说明,有必要新建一个测试项目(暂且为“formtest”吧),包含三张页面足矣(default.aspx、login.aspx、userinfo.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 表单认证中的 deny 与 allow 及保护 .htm 等文件

 

 

我闪先


 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表