ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

asp.net Form验证

2022-06-17 11:01:55  阅读:195  来源: 互联网

标签:asp Form 验证 认证 ASP net aspx NET


asp.net Form验证
ASP.NET的程序员们是否对认证代码的编写熟悉呢?是否在写认证代码的时候都套用了同一种方法,并且想尝试写点新鲜的呢?本文就来讲讲使用Form认证时遇到的一些问题,以及使用过程用到的一些技巧吧。
总结一下,对于 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> 
 <authorization> <deny users="?"> </deny> </authorization>
3、找到换成
 

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认证退出代码:
System.Web.Security.FormsAuthentication.SignOut();

四、如何判断ASP.NET认证与否及获取ASP.NET认证 后的用户信息
有的时候,在同一张页面需要判断用户是否已经登录,然后再呈现不同的布局。有人喜欢用Session来判断,在此我想告诉大家还有一种方法,且看下面代码:
 
if(User.Identity.IsAuthenticated){//你已通过ASP.NET认证,知道该怎么做了吧?}
User.Identity 还有两个属性AuthenticationType(验证类型)与 Name(用户名称)

标签:asp,Form,验证,认证,ASP,net,aspx,NET
来源: https://www.cnblogs.com/devgis/p/16384961.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有