日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

ASP.NET Forms驗證(自定義、角色提供程序)_.Net教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:剖析ASP.NET AJAX的面向?qū)ο笏枷?/a>
人們期待已久的ASP.NET AJAX v1.0正式版終于發(fā)布了�,F(xiàn)在你能用Microsoft ASP.NET AJAX的javascript很容易的寫出豐富的、交互式的web應(yīng)用。尤其值得關(guān)注的是Microsoft AJAX Library增加了面向?qū)?/p>

以前開發(fā)項目時經(jīng)常是自己開發(fā)一套用戶權(quán)限管理系統(tǒng)進(jìn)行驗證,比較靈活。最近為了單點登錄的問題又把Asp.Net自帶的驗證方式看了一遍,發(fā)現(xiàn)這種方式也比較方便,功能也還可以。在Asp.Net提供了三種常用的驗證方式:Windows方式是和IIS結(jié)合起來可以實現(xiàn)基本、摘要、集成 Windows等身份驗證;Passport方式是使用Windows Live ID的帳戶來進(jìn)行統(tǒng)一驗證的;Forms方式是使用常見的表單來實現(xiàn)驗證。

本文主要就是討論Forms驗證方式普通實現(xiàn)、自定義實現(xiàn)、自定義角色提供程序、如何單點登錄(可和MOSS結(jié)合)等幾個方面。

一、普通實現(xiàn)方式

這種方式是最簡單的,只需要配置一下就可以了。

1、執(zhí)行aspnet_regsql命令建立數(shù)據(jù)庫

aspnet_regsql命令在C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727目錄下,按提示運行就可以了

2、新建一個web網(wǎng)站

在Web.Config中加入配置:

<connectionStrings>
<add name="MySqlConnection" connectionString="Data Source=dbserver;Initial Catalog=database;user id=userid;password=****;" />
</connectionStrings>

<system.web>
<authorization>
<deny users="?"/>
</authorization>
<authentication mode="Forms">
<forms loginUrl="login.aspx" name=".ASPXAUTH"/>
</authentication>

<membership defaultProvider="SqlProvider">
<providers>
<clear />
<add connectionStringName="MySqlConnection" applicationName="MyApplication"
enablePasswordRetrieval
="false" enablePasswordReset="true" requiresQuestionAndAnswer="true"
requiresUniqueEmail
="true" passwordFormat="Hashed" name="SqlProvider"
type
="System.Web.Security.SqlMembershipProvider" />
</providers>
</membership>

</system.web>

主要就是指定Forms驗證使用的數(shù)據(jù)庫,如果不指定數(shù)據(jù)庫會使用本機默認(rèn)的aspnetdb 數(shù)據(jù)庫

deny users="?"表示不允許匿名用戶訪問,也就是說當(dāng)匿名用戶訪問時自動跳轉(zhuǎn)到下面配置的login.aspx頁面。
至于authorization和authentication節(jié)的其他屬性可以參考MSDN,里面有很詳細(xì)的介紹。

3、在網(wǎng)站里創(chuàng)建Default.aspx和Login.aspx頁面

在Login.aspx頁面里面放入LoginCreateUserWizard控件(因為我們新建的庫中一個用戶也沒有,CreateUserWizard控件只是用來建立測試用戶的,建好用戶后可以把這個控件刪除)
在Default.aspx頁面中隨便放入一些內(nèi)容。

當(dāng)我們訪問Default.aspx時就會自動轉(zhuǎn)入Login.aspx進(jìn)行驗證了。

二、自定義實現(xiàn)方式

采用第一種方式時會要求建立一個數(shù)據(jù)庫,很多表,可能并不符合我們自己的業(yè)務(wù)要求�?梢允褂靡韵碌淖远x方式

1、利用Login控件的Authenticate事件

這個事件就是用來進(jìn)行驗證的,可以通過指定true值表示驗證通過:

protected void Login1_Authenticate(object sender, AuthenticateEventArgs e)
{
//判斷用戶名密碼是否正確
//
e.Authenticated = true;
}

2、完全拋開Login等控件,自己寫代碼

其實Login控件的核心主要也就是往Cookie里面放入一些值,那么我們可以在自己的代碼中來進(jìn)行這個操作:

protected void Button1_Click(object sender, EventArgs e)
{
//判斷用戶名密碼是否正確
//.
FormsAuthentication.SetAuthCookie(userName, false);
if (Context.Request["ReturnUrl"] != null)
{
Response.Redirect(Context.Request[
"ReturnUrl"]);
}

else
{
Response.Redirect(FormsAuthentication.DefaultUrl);
}

}

采用以上兩種方式就不用建立默認(rèn)的數(shù)據(jù)庫了,直接使用我們的邏輯進(jìn)行驗證操作

三、自定義角色提供程序

以上說的都是用戶級別的驗證,在有的情況下需要根據(jù)角色來進(jìn)行驗證,比如指定某個目錄或某個aspx文件只能讓哪幾個角色的用戶訪問,根據(jù)角色來控制的話比較方便靈活。

1、在登錄驗證的時候把角色信息也保存到Cookie中去:

protected void Button1_Click(object sender, EventArgs e)
{
//判斷用戶名密碼是否正確
//.

//得到用戶的角色,測試時暫時寫死
string userRoles = "Admins,testst";
FormsAuthenticationTicket Ticket
= new FormsAuthenticationTicket(1, user, DateTime.Now, DateTime.Now.AddMinutes(30), false, userRoles, "/");
string HashTicket = FormsAuthentication.Encrypt(Ticket);

//把角色信息保存到Cookie中去
HttpCookie UserCookie = new HttpCookie(FormsAuthentication.FormsCookieName, HashTicket);
Response.Cookies.Add(UserCookie);

if (Context.Request["ReturnUrl"] != null)
{
Response.Redirect(Context.Request[
"ReturnUrl"]);
}

else
{
Response.Redirect(FormsAuthentication.DefaultUrl);
}

}

把角色信息加密成特定的格式保存。

2、自定義角色提供程序

如果要按照角色進(jìn)行驗證的話,肯定要涉及到角色提供程序,在默認(rèn)情況下也是會去連接默認(rèn)的數(shù)據(jù)庫的,我們可以自己寫一個角色提供程序來實現(xiàn)自己的邏輯。
首先在web.config中加入配置:


這個就是指定我們的角色提供類MyRoleProvider。

這個類必須從System.Web.Security.RoleProvider繼承,只要重載實現(xiàn)一個方法就可以了(其他方法返回異常):


public override string[] GetRolesForUser(string username)
{
FormsIdentity Id
= HttpContext.Current.User.Identity as FormsIdentity;
if (Id != null)
{
return Id.Ticket.UserData.Split(new Char[] { ',' });
}

return null;
}

也就是從我們之前保存到Cookie中的值取得用戶角色(FormsAuthentication會自動把保存的cookie轉(zhuǎn)化成User內(nèi)的值)

之后我們就可以在web.config中配置角色驗證規(guī)則了:

<location path="admin">
<system.web>
<authorization>
<allow roles="Admins"/>
<deny users="*"/>
</authorization>
</system.web>
</location>

或者也可以在代碼中判斷:

bool a = User.IsInRole("testt");

判斷起來還是很方便的。

四、單點登錄

使用Forms的單點登錄主要是通過machineKey的配置,machineKey 元素對密鑰進(jìn)行配置,以便將其用于對 Forms 身份驗證 Cookie 數(shù)據(jù)和視圖狀態(tài)數(shù)據(jù)進(jìn)行加密和解密,并將其用于對進(jìn)程外會話狀態(tài)標(biāo)識進(jìn)行驗證

使用這種方式的單點登錄目前只能實現(xiàn)相同主機或相同子域站點之間的同步登錄,比如www.cnblogs.com和firstyi.cnblogs.com可以實現(xiàn),但是www.cnblogs.com和www.sina.com.cn就不能實現(xiàn)了,對于非同一父域名下的域名間不能跨站登錄

主要配置如下:

<machineKey validationKey="282487E295028E59B8F411ACB689CCD6F39DDD21E6055A3EE480424315994760ADF21B580D8587DB675FA02F79167413044E25309CCCDB647174D5B3D0DD9141" decryptionKey="8B6697227CBCA902B1A0925D40FAA00B353F2DF4359D2099" validation="SHA1"/>
<authentication mode="Forms">
<forms loginUrl="login.aspx" name=".ASPXAUTH1" domain=".cnblogs.com" />
</authentication>

要實現(xiàn)單點登錄的多個web站點的machineKey必須一樣,forms里面的name和domain也必須一樣

這樣配置好之后,在其中一個站點登錄后再調(diào)轉(zhuǎn)到另一個站點就不需要再次登錄了。

注:如果MOSS網(wǎng)站采用Forms驗證方式的話,只要把MOSS站點的對應(yīng)配置改成和自己的Asp.Net站點一致,那么可以從自己的站點直接進(jìn)入MOSS站點,也不需要重新登錄(MOSS站點和自己的站點要有相同的用戶名)

其他:

Forms驗證之后可以使用以下方法退出登錄:

FormsAuthentication.SignOut();


另外這些登錄的后臺Module是配置在C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\CONFIG\web.config文件中的:

<add name="WindowsAuthentication" type="System.Web.Security.WindowsAuthenticationModule"/>
<add name="FormsAuthentication" type="System.Web.Security.FormsAuthenticationModule"/>
<add name="PassportAuthentication" type="System.Web.Security.PassportAuthenticationModule"/>

附:


分享:ASP.NET緩存:方法分析和實踐示例
盡早緩存;經(jīng)常緩存 您應(yīng)該在應(yīng)用程序的每一層都實現(xiàn)緩存。向數(shù)據(jù)層、業(yè)務(wù)邏輯層、UI 或輸出層添加緩存支持。內(nèi)存現(xiàn)在非常便宜 — 因此,通過以智能的方式在整個應(yīng)用程序中實現(xiàn)緩存,可以

來源:模板無憂//所屬分類:.Net教程/更新時間:2008-08-22
相關(guān).Net教程