网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 手机学院 | 邮件系统 | 网络安全 | 认证考试
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.ASP.Net中的MD5加密.
.解决文件下载弹出窗体被拦截 .
.DataGrid实例(简单易懂,无复杂.
..net 做的IP 访问限制 .
.ASP.NET2.0实现网站的自动升级 .
.Asp.Net基于forms的验证机制.
.url传递中文的解决方案.
.Scott Mitchell 的ASP.NET 2.0数.
.asp.net 2.0里当readonly遇上ena.
.在atlas里面的UpdatePanel控件中.
.获取汉字拼音的第一个字母 .
.asp.net 2.0 权限树的控制.
.ASP.NET2.0下为GridView添加服务.
.asp.net menu "Operation aborte.
.ASP.NET 2.0 正式版中无刷新页面.
.Asp.net &C#开发中的一些注意事项.
.ASP.NET页面下载程序.
..net 下用javascript调用webserv.
.ASP.NET里常用的JS.
.用ASP.NET2.0在数据库中存储二进.

Asp.Net基于forms的验证机制

发表日期:2008-12-12

  项目需要研究了下Asp.Net的基于forms的验证机制 

  构建基于forms的验证机制过程如下:
    1,设置IIS为可匿名访问和asp.net web.config中设置为form验证
    2,检索数据存储验证用户,并检索角色(如果不是基于角色可不用)

    简单无role方式:

    使用FormsAuthenticationTicket创建一个Cookie并回发到客户端,并存储 角色到票中,如:
     FormsAuthentication.SetAuthCookie(Username,true | false)
    cookies保存时间:
    HttpContext.Current.Response.Cookies[FormsAuthentication.FormsCookieName].Expires=DateTime.Now.AddDays(1)

    如果需要存储角色方式:  view plaincopy to clipboardprint?
 FormsAuthenticationTicket authTicket = new   
 FormsAuthenticationTicket(   
 1, // version   
 txtUserName.Text, // user name   
 DateTime.Now, // creation   
 DateTime.Now.AddMinutes(20),// Expiration   
 false, // Persistent   
 roles ); // User data  
    //roles是一个角色字符串数组   
 string encryptedTicket = FormsAuthentication.Encrypt(authTicket); //加密  

 FormsAuthenticationTicket authTicket = new
 FormsAuthenticationTicket(
 1, // version
 txtUserName.Text, // user name
 DateTime.Now, // creation
 DateTime.Now.AddMinutes(20),// Expiration
 false, // Persistent
 roles ); // User data
    //roles是一个角色字符串数组
 string encryptedTicket = FormsAuthentication.Encrypt(authTicket); //加密    存入Cookie view plaincopy to clipboardprint?
HttpCookie authCookie =   
new HttpCookie(FormsAuthentication.FormsCookieName,   
encryptedTicket);   
 
Response.Cookies.Add(authCookie);  

 HttpCookie authCookie =
 new HttpCookie(FormsAuthentication.FormsCookieName,
 encryptedTicket);

 Response.Cookies.Add(authCookie);    在Application_AuthenticateRequest事件中处理程序中(Global.asax)中,使用票创建IPrincipal对象并存在HttpContext.User中代码: view plaincopy to clipboardprint?
protected void Application_AuthorizeRequest(object sender, System.EventArgs e)  
{  
 HttpApplication App = (HttpApplication) sender;  
 HttpContext Ctx = App.Context ; //获取本次Http请求相关的HttpContext对象  
 if (Ctx.Request.IsAuthenticated == true) //验证过的用户才进行role的处理  
 {  
 FormsIdentity Id = (FormsIdentity)Ctx.User.Identity ;  
 FormsAuthenticationTicket Ticket = Id.Ticket ; //取得身份验证票  
 string[] Roles = Ticket.UserData.Split (',') ; //将身份验证票中的role数据转成字符串数组  
 Ctx.User = new GenericPrincipal (Id, Roles) ; //将原有的Identity加上角色信息新建一个GenericPrincipal表示当前用户,这样当前用户就拥有了role信息  
 }  

protected void Application_AuthorizeRequest(object sender, System.EventArgs e)
{
 HttpApplication App = (HttpApplication) sender;
 HttpContext Ctx = App.Context ; //获取本次Http请求相关的HttpContext对象
 if (Ctx.Request.IsAuthenticated == true) //验证过的用户才进行role的处理
 {
 FormsIdentity Id = (FormsIdentity)Ctx.User.Identity ;
 FormsAuthenticationTicket Ticket = Id.Ticket ; //取得身份验证票
 string[] Roles = Ticket.UserData.Split (',') ; //将身份验证票中的role数据转成字符串数组
 Ctx.User = new GenericPrincipal (Id, Roles) ; //将原有的Identity加上角色信息新建一个GenericPrincipal表示当前用户,这样当前用户就拥有了role信息
 }
}   需要对某些页面进行角色控制,有两种方法:
    1、web.config中加 view plaincopy to clipboardprint?
<location path="EditPost.aspx">   
<system.web>   
<authorization>   
<allow roles="RoleName" />   
<deny users="?" />   
</authorization>   
</system.web>   
</location>  

 <location path="EditPost.aspx">
 <system.web>
 <authorization>
 <allow roles="RoleName" />
 <deny users="?" />
 </authorization>
 </system.web>
 </location>     2、把只能是某种角色访问的文件放在同一目录下,在此目录下添加一个web.config view plaincopy to clipboardprint?
<configuration>   
<system.web>   
<authorization>   
<allow roles="RoleName" />   
<deny users="*" />   
</authorization>   
</system.web>   
</configuration>  

 <configuration>
 <system.web>
 <authorization>
 <allow roles="RoleName" />
 <deny users="*" />
 </authorization>
 </system.web>
 </configuration>     说明:子目录的web.config设置优先于父目录的web.config设置

以上参考:http://www.cnblogs.com/kwklover/archive/2004/06/29/19455.aspx
     http://www.donews.net/robinblood/archive/2005/04/30/358041.aspx

上一篇:页面刷新后WebControl的动态添加内容不重生成的解决方案 人气:195
下一篇:使用DES对称加密代码,支持中文 人气:203
浏览全部Asp.Net的内容 Dreamweaver插件下载 网页广告代码 2009年新年快乐