成都网站建设设计

将想法与焦点和您一起共享

怎么用Form表单实现ASP.NET认证

这篇文章主要讲解了“怎么用Form表单实现ASP.NET认证”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用Form表单实现ASP.NET认证”吧!

创新互联建站长期为1000+客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为李沧企业提供专业的成都网站制作、做网站,李沧网站改版等技术服务。拥有十多年丰富建站经验和众多成功案例,为您定制开发。

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、找到下列文字 把它改成:

 forms> authentication>

3、找到换成

deny>authorization>

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

        forms> deny> authentication>

若要问是谁把放入 中的,我会很荣幸地告诉你,那是 N 年前的我: 与 都是以 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、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 。

感谢各位的阅读,以上就是“怎么用Form表单实现ASP.NET认证”的内容了,经过本文的学习后,相信大家对怎么用Form表单实现ASP.NET认证这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!


网站栏目:怎么用Form表单实现ASP.NET认证
网页路径:http://chengdu.cdxwcx.cn/article/pppjeo.html